我需要记录每个 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;
关于laravel - 如何在 Laravel 中间件的终止函数中记录 api 请求的响应,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49995100/