如何使用ActionFilterAttribute实现API日志的记录
发表于:2025-11-14 作者:千家信息网编辑
千家信息网最后更新 2025年11月14日,本篇内容主要讲解"如何使用ActionFilterAttribute实现API日志的记录",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"如何使用Action
千家信息网最后更新 2025年11月14日如何使用ActionFilterAttribute实现API日志的记录
本篇内容主要讲解"如何使用ActionFilterAttribute实现API日志的记录",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"如何使用ActionFilterAttribute实现API日志的记录"吧!
实现方式
1、首先在进入action的时候,定义OnActionExecuting。
public override void OnActionExecuting(ActionExecutingContext context) { base.OnActionExecuting(context); // 后续添加了获取请求的请求体,如果在实际项目中不需要删除即可 long contentLen = context.HttpContext.Request.ContentLength == null ? 0 : context.HttpContext.Request.ContentLength.Value; if (contentLen > 0) { // 读取请求体中所有内容 System.IO.Stream stream = context.HttpContext.Request.Body; if (context.HttpContext.Request.Method == "POST") { stream.Position = 0; } byte[] buffer = new byte[contentLen]; stream.Read(buffer, 0, buffer.Length); // 转化为字符串 RequestBody = System.Text.Encoding.UTF8.GetString(buffer); } ActionArguments = Newtonsoft.Json.JsonConvert.SerializeObject(context.ActionArguments); Stopwatch = new Stopwatch(); Stopwatch.Start(); }2、定义Stopwatch ,计算方法的耗时。
private string ActionArguments { get; set; } /// /// 请求体中的所有值 /// private string RequestBody { get; set; } private Stopwatch Stopwatch { get; set; }3、结束的时候,把信息打印出来OnActionExecuted。
public override void OnActionExecuted(ActionExecutedContext context) { base.OnActionExecuted(context); Stopwatch.Stop(); string url = context.HttpContext.Request.Host + context.HttpContext.Request.Path + context.HttpContext.Request.QueryString; string method = context.HttpContext.Request.Method; string controller = context.Controller.ToString(); string action = context.ActionDescriptor.DisplayName; string token = ""; if (context.HttpContext.Request != null && context.HttpContext.Request.Headers != null && context.HttpContext.Request.Headers["Authorization"].Count > 0) { token = context.HttpContext.Request.Headers["Authorization"]; } string qs = ActionArguments; dynamic result = context?.Result?.GetType()?.Name == "EmptyResult" ? new { Value = "无返回结果" } : context?.Result as dynamic; string res = "在返回结果前发生了异常"; try { if (result != null) { res = Newtonsoft.Json.JsonConvert.SerializeObject(result.Value); } } catch (System.Exception) { res = "日志未获取到结果,返回的数据无法序列化"; } NLogger.Info( $"地址:{url} \n " + $"controller:{controller} \n " + $"action:{action} \n " + $"token:{token} \n " + $"方式:{method} \n " + $"请求体:{RequestBody} \n " + $"参数:{qs}\n " + $"结果:{res}\n " + $"耗时:{Stopwatch.Elapsed.TotalMilliseconds} 毫秒(指控制器内对应方法执行完毕的时间)"); }4、控制器调用LogAttribute。
////// /// [Produces("application/json")] [LogAttribute] [CustomExceptionFilterAttribute] public class DefaultController : Controller { }
完整代码
using CompanyName.ProjectName.Core; using Microsoft.AspNetCore.Mvc.Filters; using System.Diagnostics; namespace CompanyName.ProjectName.HttpApi.Host.Code { /// /// 拦截器 /// public class LogAttribute : ActionFilterAttribute { private string ActionArguments { get; set; } /// /// 请求体中的所有值 /// private string RequestBody { get; set; } private Stopwatch Stopwatch { get; set; } /// /// /// /// public override void OnActionExecuting(ActionExecutingContext context) { base.OnActionExecuting(context); // 后续添加了获取请求的请求体,如果在实际项目中不需要删除即可 long contentLen = context.HttpContext.Request.ContentLength == null ? 0 : context.HttpContext.Request.ContentLength.Value; if (contentLen > 0) { // 读取请求体中所有内容 System.IO.Stream stream = context.HttpContext.Request.Body; if (context.HttpContext.Request.Method == "POST") { stream.Position = 0; } byte[] buffer = new byte[contentLen]; stream.Read(buffer, 0, buffer.Length); // 转化为字符串 RequestBody = System.Text.Encoding.UTF8.GetString(buffer); } ActionArguments = Newtonsoft.Json.JsonConvert.SerializeObject(context.ActionArguments); Stopwatch = new Stopwatch(); Stopwatch.Start(); } /// /// /// /// public override void OnActionExecuted(ActionExecutedContext context) { base.OnActionExecuted(context); Stopwatch.Stop(); string url = context.HttpContext.Request.Host + context.HttpContext.Request.Path + context.HttpContext.Request.QueryString; string method = context.HttpContext.Request.Method; string controller = context.Controller.ToString(); string action = context.ActionDescriptor.DisplayName; string token = ""; if (context.HttpContext.Request != null && context.HttpContext.Request.Headers != null && context.HttpContext.Request.Headers["Authorization"].Count > 0) { token = context.HttpContext.Request.Headers["Authorization"]; } string qs = ActionArguments; dynamic result = context?.Result?.GetType()?.Name == "EmptyResult" ? new { Value = "无返回结果" } : context?.Result as dynamic; string res = "在返回结果前发生了异常"; try { if (result != null) { res = Newtonsoft.Json.JsonConvert.SerializeObject(result.Value); } } catch (System.Exception) { res = "日志未获取到结果,返回的数据无法序列化"; } NLogger.Info( $"地址:{url} \n " + $"controller:{controller} \n " + $"action:{action} \n " + $"token:{token} \n " + $"方式:{method} \n " + $"请求体:{RequestBody} \n " + $"参数:{qs}\n " + $"结果:{res}\n " + $"耗时:{Stopwatch.Elapsed.TotalMilliseconds} 毫秒(指控制器内对应方法执行完毕的时间)"); } } }到此,相信大家对"如何使用ActionFilterAttribute实现API日志的记录"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
结果
日志
内容
方法
实际
方式
制器
参数
地址
字符
字符串
序列
数据
时候
时间
项目
学习
实用
更深
代码
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
将网站发布到服务器
文献数据库的检索途径
中国移动通信网络技术待遇
网络技术it化
辛达苟萨 服务器
软件开发去哪学
三国志战略版服务器会想通吗
临沂阿帕网络技术
网络安全人员保密协议范本
服务器半导体研究报告
网络安全即服务探索
如何进入手机版我的世界的服务器
我的世界云梦服务器如何组队
mysql换oracle数据库
云集赛事软件开发
网络安全手抄报复杂三年级上册
圆点网络技术
多重网络安全吗
关于网络安全的童诗童谣
重庆合川区安卓软件开发企业
钊雄软件开发
科技it互联网公司
网络技术it化
工行软件开发季度奖
中国5g网络技术公司
最下载软件开发
激战2电信二区服务器
汉末霸业获取服务器数据失败
我的世界服务器查看金币排行榜
软件开发企业效益怎样