如何在 Laravel 中间件的终止函数中记录 api 请求的响应

How to log responses of an api request in terminate function of a Laravel middleware

我需要记录每个 api 请求的响应。为此,我创建了一个中间件,并在该中间件的终止函数中使用了 ResponseTrait。一切正常,直到我使用 ResponseTrait 的状态函数。我尝试了 $this->status 和 self::status 但没有任何效果。当我使用这个函数时它说语法错误。以下是我的中间件代码。

namespace App\Http\Middleware;
use Closure;
use Illuminate\Support\Facades\Auth;
use Spatie\HttpLogger\LogWriter;
use Illuminate\Support\Facades\Log;
use Illuminate\Http\ResponseTrait;

class logger implements LogWriter
{
   use ResponseTrait;
   /**
    * Handle an incoming request.
    *
    * @param  \Illuminate\Http\Request  $request
    * @param  \Closure  $next
    * @return mixed
    */
    public function handle($request, Closure $next)
    {
      return $next($request);
    }
    public function terminate($request)
    {
      $responseCode = $this->status();
    }
 }

响应状态来自 $next($request); 的结果,因此您需要像这样引用它:

$response = $next($request);
$status = $response->status();
return $response;