首页 > 后端开发 > php教程 > 在Laravel应用程序中添加请求上下文

在Laravel应用程序中添加请求上下文

Robert Michael Kim
发布: 2025-03-07 00:24:21
原创
806 人浏览过

Adding Request Context in Laravel Applications

Laravel 的 Context facade 通过允许您在整个请求生命周期中添加持久性元数据来增强应用程序的洞察力。此上下文会自动使用有价值的调试信息丰富您的日志。

以下是一个在中间件和 API 请求日志记录中使用请求上下文的实用示例:

<?php

namespace App\Http\Middleware;

use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Context;
use Illuminate\Support\Str;

class ApiRequestLogger
{
    public function handle(Request $request, Closure $next)
    {
        // 添加基本的请求上下文
        Context::add('request_id', Str::uuid()->toString());
        Context::add('path', $request->path());
        Context::add('method', $request->method());
        // 如果已认证,则添加用户上下文
        if ($request->user()) {
            Context::add('user_id', $request->user()->id);
            Context::add('api_key', $request->user()->api_key);
        }
        // 添加性能指标
        $startTime = microtime(true);

        $response = $next($request);
        Context::add('response_time', round((microtime(true) - $startTime) * 1000, 2));
        Context::add('status_code', $response->getStatusCode());
        // 记录 API 请求
        Log::info('API request processed');

        return $response;
    }
}
登录后复制

另一个例子展示如何在自定义类中使用Context Facade:

<?php

use Illuminate\Support\Facades\Context;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Log;
use Illuminate\Support\Str;

class RequestContext
{
    public function __construct()
    {
        Context::add('request_id', Str::uuid()->toString());
    }

    public function addUserContext()
    {
        if (Auth::check()) {
            Context::add('user_id', Auth::id());
            Context::add('user_type', Auth::user()->type);
        }
    }

    public function logAction(string $action)
    {
        Log::info("User performed {$action}");
    }
}
登录后复制

Context facade 通过提供在整个请求生命周期中持续存在的宝贵元数据来丰富应用程序的日志记录,从而使调试和监控更加有效。

以上是在Laravel应用程序中添加请求上下文的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板