Explorar o código

接口请求日志

lizhen_gitee %!s(int64=2) %!d(string=hai) anos
pai
achega
249b1d0c81

+ 22 - 17
application/api/library/ExceptionHandle.php

@@ -13,25 +13,30 @@ class ExceptionHandle extends Handle
 
     public function render(Exception $e)
     {
-        // 在生产环境下返回code信息
-        if (!\think\Config::get('app_debug')) {
-            $statuscode = $code = 500;
-            $msg = 'An error occurred';
-            // 验证异常
-            if ($e instanceof \think\exception\ValidateException) {
-                $code = 0;
-                $statuscode = 200;
-                $msg = $e->getError();
-            }
-            // Http异常
-            if ($e instanceof \think\exception\HttpException) {
-                $statuscode = $code = $e->getStatusCode();
-            }
-            return json(['code' => $code, 'msg' => $msg, 'time' => time(), 'data' => null], $statuscode);
+        //return parent::render($e);
+        $statuscode = $code = 500;
+        $msg = $e->getMessage();
+        // 验证异常
+        if ($e instanceof \think\exception\ValidateException) {
+            $code = 0;
+            $statuscode = 200;
+            $msg = $e->getError();
+
+        }
+        // Http异常
+        if ($e instanceof \think\exception\HttpException) {
+            $statuscode = $code = $e->getStatusCode();
+            $msg = $e->getMessage();
+        }
+
+        $result = ['code' => $code, 'msg' => $msg, 'time' => time(), 'data' => null];
+
+        //记录app异常返回结果
+        if(defined('API_REQUEST_ID')) { //记录app正常返回结果
+            db('api_request_log')->where('id',API_REQUEST_ID)->update(['result'=>json_encode($result)]);
         }
 
-        //其它此交由系统处理
-        return parent::render($e);
+        return json($result, $statuscode);
     }
 
 }

+ 35 - 0
application/common/controller/Api.php

@@ -76,6 +76,8 @@ class Api
 
         // 控制器初始化
         $this->_initialize();
+        //日志
+        $this->request_log();
 
         // 前置操作方法
         if ($this->beforeActionList) {
@@ -391,4 +393,37 @@ class Api
         return true;
     }
 
+
+    /*
+     * api 请求日志
+     * */
+    protected function request_log(){
+        //api_request_log
+        $modulename     = $this->request->module();
+        $controllername = $this->request->controller();
+        $actionname     = $this->request->action();
+
+        $data = [
+            'uid'   => $this->auth->id,
+            'api'   => $modulename.'/'.$controllername.'/'.$actionname,
+            'params' => json_encode($this->request->request()),
+            'addtime'  => time(),
+            'adddatetime'  => date('Y-m-d H:i:s'),
+            'ip'   => request()->ip(),
+        ];
+        $request_id = db('api_request_log')->insertGetId($data);
+        defined('API_REQUEST_ID') or define('API_REQUEST_ID', $request_id);
+
+    }
+
+    protected function request_log_update($log_result){
+        if(defined('API_REQUEST_ID')) { //记录app正常返回结果
+            if(strlen(json_encode($log_result['data'])) > 10000) {
+                $log_result['data'] = '数据太多,不记录';
+            }
+            db('api_request_log')->where('id',API_REQUEST_ID)->update(['result'=>json_encode($log_result)]);
+        }
+    }
+
+
 }