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

标签 laravel laravel-5.4 laravel-5.5 laravel-5.6

我需要记录每个 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/

相关文章:

php - 如何在 Laravel 的 MySQL 查询中的 where 子句中使用数组

php - 相当于mysql/laravel中的qualify语句?

vuejs2 - 推杆没有定义! Laravel 5.4 与 Laravel Echo

php - Laravel 5.4 Eloquent 查询

php - 如何在 Laravel 中设置 OpenID Connect 客户端?

php - Laravel,使用jquery ajax返回响应400错误

php - eloquent上如何统计每组item的数量

php - Laravel 5.5 权限 - 用户没有正确的角色

php - 在 laravel 中将数组数据保存到 mySQL 的好方法是什么

php - 如何从路由请求参数中删除现有项目? - 拉维尔 5.5