123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- <?php
- namespace App\Http\Middleware;
- use App\Http\Utils\LoggerFactoryUtil;
- use App\Models\RequestLogModel;
- use Closure;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\Config;
- use Tool\ShanTaoTool\MqTool;
- class RequestLogMiddleware
- {
-
- public function handle(Request $request, Closure $next, $guard = null)
- {
-
- $param = $request->all();
- $startTime = microtime(true);
-
- if($request->header("traceId")){
- $traceId= $request->header("traceId");
- }else{
- $traceId = md5(uniqid().time());
- }
- $requestId = floor(microtime(true)*1000);
- LoggerFactoryUtil::setRequestId($requestId);
- $_GET["traceId"] = $traceId;
-
- LoggerFactoryUtil::setStartTime($startTime);
-
- $response = $next($request);
-
- $endTime = microtime(true);
- $responseData = $response->getContent();
-
- $requestLog = "";
- if(LoggerFactoryUtil::getMessage()){
- $requestLog = json_encode(LoggerFactoryUtil::getMessage());
- }
-
- $requestSqlLog = "";
- if(LoggerFactoryUtil::getSqlMessage()){
- $requestSqlLog = json_encode(LoggerFactoryUtil::getSqlMessage());
- }
-
- $path = $request->path();
- $notLogArr = [
- "api/loadswagger",
- ];
- if(env("REQUEST_LOG_FLAG")&& !in_array($path,$notLogArr)){
- $mqMessage = [
- "requestPath"=>$request->path(),
- "requestParam"=>json_encode($param),
- "requestResponse"=>$responseData,
- "requestSqlLog"=>$requestSqlLog,
- "requestLog"=>$requestLog,
- "requestProjectName"=>"daogou",
- "createdAt"=>$startTime,
- "updatedAt"=>$endTime,
- "requestId"=>$requestId,
- "uniqueTraceId"=>$traceId
- ];
- try{
- if(LoggerFactoryUtil::getIsPush()==0){
- MqTool::pushLogMessage(json_encode($mqMessage),"daogouLogKey");
- }
- }catch (\Exception $exception){}finally{}
- }
- return $response;
- }
- }
|