laravel 中间件记录日志

前提

我希望通过中间件记录用户的请求数据、我的返回数据,如果出现异常捕获异常。

代码

路由文件:追加中间件api-logging,用于记录日志

Route::prefix('api')->middleware(['api', 'api-logging'])->group(function () {...路由内容
});
namespace App\Http;
class Kernel extends HttpKernel
{...其他内容protected $routeMiddleware = [... 其他中间件'api-logging' => \App\Http\Middleware\ApiLoggingMiddleware::class,];
}

重点:中间件的编写

<?phpnamespace App\Http\Middleware;use Closure;
use Illuminate\Http\Request;
use App\Models\GameThirdPartyCallback;class ApiLoggingMiddleware
{public function handle(Request $request, Closure $next){$requestHeaders = $request->header();$requestData = $request->all();$source = $request->header('referer') ?? $request->ip();try {// 执行请求并获取响应$response = $next($request);$responseStatus = $response->status();$responseContent = $response->getContent();} catch (\Exception $exception) {// 记录异常信息GameThirdPartyCallback::create(['request_headers' => json_encode($requestHeaders),'callback_data' => json_encode($requestData),'response_status' => 500, // 或其他适当的错误状态码'response_content' => 'An error occurred: ' . $exception->getMessage(),'sources' => $source]);// 重新抛出异常,交由Laravel处理throw $exception;}// 记录正常的响应数据GameThirdPartyCallback::create(['request_headers' => json_encode($requestHeaders),'callback_data' => json_encode($requestData),'response_status' => $responseStatus,'response_content' => $responseContent,'sources' => $source]);return $response;}
}

我希望在,下面这段可以当 n e x t ( next( next(request); 出现异常被捕获

try {// 执行请求并获取响应$response = $next($request);} catch (\Exception $exception) {// 重新抛出异常,交由Laravel处理throw $exception;}

然而并不行,如果控制器中出现了异常,会被laravel的全局异常处理机制捕获,$response = $next($request); 会返回捕获后的异常处理的类,也就是异常已经被处理掉了

最终处理方案

在全局异常处理的时候,将异常内容插入到request中,然后在中间件去获取这个自定义的属性

  1. 全局处理文件中,加入下面这段代码

namespace App\Exceptions;use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
use Throwable;class Handler extends ExceptionHandler
{/*** Render an exception into an HTTP response.** @param  \Illuminate\Http\Request  $request* @param  \Throwable  $exception* @return \Symfony\Component\HttpFoundation\Response*/public function render($request, Throwable $exception){// 这里这段的内容是为了让异常内容可以被中间件获取// 因为控制器的异常会被laravel全局异常直接捕获,导致中间件获取的内容是异常页面$request->attributes->set('exception_message', $exception->getMessage());return parent::render($request, $exception);}
}

然后中间件中获取exception_message

<?phpnamespace App\Http\Middleware;use Closure;
use Illuminate\Http\Request;
use App\Models\GameThirdPartyCallback;class ApiLoggingMiddleware
{public function handle(Request $request, Closure $next){$requestHeaders = $request->header();$requestData = $request->all();$source = $request->header('referer') ?? $request->ip();$response = $next($request);  // 如果这里产生了异常,不会在这里try catch。而是直接返回了response的错误内容$responseStatus = $response->status();if ($responseStatus >= 400 && $responseStatus < 600) {GameThirdPartyCallback::create(['request_headers' => json_encode($requestHeaders),'callback_data' => json_encode($requestData),'response_status' => $responseStatus,'response_content' => $request->attributes->get("exception_message"),'sources' => $source]);} else {...}return $response;}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/618693.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IntersectionObserver

IntersectionObserver 这个API主要实现图片懒加载、加载更多等等。 该API作用是观察两个元素之间有没有交叉&#xff0c;有没有重叠 现在要做的是当图片跟视口有交叉的情况下&#xff0c;把data-src的图片路径替换给src属性 //第一个参数是 回调&#xff0c;第二个参数的 配置…

HarmonyOS4.0 系列——06、渲染之条件渲染、循环渲染以及懒加载渲染

HarmonyOS4.0 系列——06、渲染之条件渲染、循环渲染以及懒加载渲染 if/else&#xff1a;条件渲染 ArkTS 提供了渲染控制的能力。条件渲染可根据应用的不同状态&#xff0c;使用 if、else 和 else if 渲染对应状态下的 UI 内容。 写法和 TS 的一样&#xff0c;简单看一下即可…

【数据结构之树和二叉树】

数据结构学习笔记---007 数据结构之树和二叉树概念篇1、树的概念和结构1.1、树的相关概念1.2、树的存储结构 2、二叉树概念及结构2.1、二叉树概念2.2、满二叉树2.3、完全二叉树2.4、满二叉树或完全二叉树的存储形式 3、堆的概念及结构3.1、堆的性质3.2、堆的意义 4、二叉树的存…

python_selenium_安装基础学习

目录 1.为什么使用selenium 2.安装selenium 2.1Chrome浏览器 2.2驱动 2.3下载selenium 2.4测试连接 3.selenium元素定位 3.1根据id来找到对象 3.2根据标签属性的属性值来获取对象 3.3根据xpath语句来获取对象 3.4根据标签的名字获取对象 3.5使用bs4的语法来获取对象…

解惑:测试圈网红工具 Jmeter 到底难在哪里

作为一名测试人员&#xff0c;你是否也曾经遇到过这些问题&#xff1a; 同样的起点&#xff0c;同样的工作时间&#xff0c;为什么别人接那么多项目&#xff0c;你还是在点点点&#xff1b;为什么别人升职了&#xff0c;而你还在原地踏步&#xff1f; 同样的工作内容&#xf…

GNU Tools使用笔记

GCC命令选项 预处理器选项 -M选项 作用&#xff1a;生成源文件的依赖关系&#xff0c;包含了该源文件所有的依赖&#xff0c;默认会发送到标准输出&#xff08;stdout&#xff09;。 示例1&#xff1a;在ubuntu中&#xff0c;新建如下main.c、main.h、head1.h、head2.h文件。…

数据库的数据类型

文章目录 前言一、数据类型数据类型分类数值类型bit类型小数类型floatdecimal 字符串类型charvarcharchar和varchar比较 日期和时间类型enum和set 前言 一、数据类型 数据类型分类 数值类型 下面我们来创建一个表&#xff0c;表中创建一个tinyint类型的数据。当我们不指定tiny…

【贪心】重构字符串

/*** 思路&#xff1a;如果s长度小于2&#xff0c;直接返回s&#xff0c;假设字符串s的长度为n。* n为偶数&#xff0c;如果字符串中的某个字符数量超过 n/2 则肯定会存在相邻的字符。* n为奇数&#xff0c;如果字符串中的某个字符的数量超过 &#xff08;n1&am…

机器学习顶会ICML 2024今日开放投稿,CCF A类,中稿率27.94%(附ICML23杰出论文+18篇高分论文)

ICML 2024今天开放投稿了&#xff01;距离截稿还有24天&#xff0c;想冲ICML的同学速度&#xff01; ICML 全称 International Conference on Machine Learning&#xff0c;由国际机器学习学会&#xff08;IMLS&#xff09;举办&#xff0c;与NIPS一同被认为是人工智能、机器学…

debian 11 arm64 aarch64 D2000 平台编译 box86 box64 笔记

参考资料 https://github.com/ptitSeb/box86/blob/master/docs/COMPILE.md 源码地址 GitHub - ptitSeb/box86: Box86 - Linux Userspace x86 Emulator with a twist, targeted at ARM Linux devices deb在线源地址&#xff08;打不开&#xff09;&#xff1a; Itais box86…

腾讯云免费服务器怎么申请?腾讯云免费服务器申请难吗?

腾讯云免费服务器申请入口 https://curl.qcloud.com/FJhqoVDP 免费服务器可选轻量应用服务器和云服务器CVM&#xff0c;轻量配置可选2核2G3M、2核8G7M和4核8G12M&#xff0c;CVM云服务器可选2核2G3M和2核4G3M配置&#xff0c;腾讯云服务器网txyfwq.com分享2024年最新腾讯云免费…

C++ 具名要求-全库范围的概念 - 一种等价关系(operator==)- 是一种严格弱序关系(operator< )

此页面中列出的具名要求&#xff0c;是 C 标准的规范性文本中使用的具名要求&#xff0c;用于定义标准库的期待。 某些具名要求在 C20 中正在以概念语言特性进行形式化。在那之前&#xff0c;确保以满足这些要求的模板实参实例化标准库模板是程序员的重担。若不这么做&#xf…

一文解析低代码平台

一、低代码概念 低代码开发平台是一种无需编码或者只需要少量代码即可快速生成应用程序的开发平台&#xff0c;通过可视化进行应用程序开发的方法&#xff0c;让不同经验水平的开发人员可以通过图形化的用户界面&#xff0c;使用拖拽组件和模型驱动的逻辑来创建网页和移动应用程…

MySQL夯实之路-存储引擎深入浅出

innoDB Mysql4.1以后的版本将表的数据和索引放在单独的文件中 采用mvcc来支持高并发&#xff0c;实现了四个标准的隔离级别&#xff0c;默认为可重复读&#xff0c;并且通过间隙锁&#xff08;next-key locking&#xff09;策略防止幻读&#xff08;查询的行中的间隙也会锁定…

Redis:原理速成+项目实战——Redis实战13(GEO实现附近商铺、滚动分页查询)

&#x1f468;‍&#x1f393;作者简介&#xff1a;一位大四、研0学生&#xff0c;正在努力准备大四暑假的实习 &#x1f30c;上期文章&#xff1a;Redis&#xff1a;原理速成项目实战——Redis实战12&#xff08;好友关注、Feed流&#xff08;关注推送&#xff09;、滚动分页查…

基于ssm的校园预点餐系统(有报告)。Javaee项目。ssm项目。

演示视频&#xff1a; 基于ssm的校园预点餐系统&#xff08;有报告&#xff09;。Javaee项目。ssm项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&#xff0c;通过Spring Sp…

案例分享:游戏行业各岗位的KPI绩效指标制定

在游戏行业中&#xff0c;岗位种类繁多&#xff0c;每个岗位的职责和要求都有所不同。因此&#xff0c;制定合理的KPI&#xff08;关键绩效指标&#xff09;是确保团队高效运作的关键。 在竞争激烈的市场环境中&#xff0c;合理的KPI不仅有助于员工明确工作方向&#xff0c;还…

Pandas实战100例 | 案例 37: 从长格式转换为宽格式

案例 37: 从长格式转换为宽格式 知识点讲解 数据格式转换是数据处理中的一个常见需求。Pandas 提供了将数据从长格式&#xff08;每行是一个观测值&#xff09;转换为宽格式&#xff08;每个观测值成为一列&#xff09;的功能。 长格式转宽格式: 使用 pivot 方法可以将数据从…

大语言模型向量数据库

大语言模型&向量数据库 LARGE LANGUAGE MODELSA. Vector Database & LLM WorkflowB. Vector Database for LLMC. Potential Applications for Vector Database on LLMD. Potential Applications for LLM on Vector DatabaseE. Retrieval-Based LLMF. Synergized Exampl…

element+vue 之图片放大器

1.安装插件 npm install vue-photo-zoom-pro2.main.js导入 // 放大镜 import VuePhotoZoomPro from vue-photo-zoom-pro Vue.use(VuePhotoZoomPro)3.页面使用 <vue-photo-zoom-pro:url"imgUrl":out-zoomer"true":scale"2"style"width:…