IActionFilter过滤器主要用于日志记录,实现方式首页创建一个类继承自Attribute, IActionFilter,并实现IActionFilter接口的OnActionExecuting、OnActionExecuted两个方法,OnActionExecuting方法在Action执行前执行,OnActionExecuted在Action执行后执行。
具体代码实例如下:创建CustomLogActionFilterAttribute类继承自Attribute, IActionFilter方法,
public class CustomLogActionFilterAttribute : Attribute, IActionFilter
    {
        private readonly ILogger<CustomLogActionFilterAttribute> _ILogger;
        public CustomLogActionFilterAttribute(ILogger<CustomLogActionFilterAttribute> iLogger) { 
            this._ILogger = iLogger;
        }
        /// <summary>
        /// action执行之前
        /// </summary>
        /// <param name="context"></param>
        public void OnActionExecuting(ActionExecutingContext context)
        {
            //获取url参数
            var para = context.HttpContext.Request.QueryString.Value;
            //获取路由中的controller
            var controllerName = context.HttpContext.GetRouteValue("controller");
            //获取路由中的action
            var actionName = context.HttpContext.GetRouteValue("action");
            _ILogger.LogInformation($"执行{controllerName}控制器{actionName}方法:参数为:{para}");
        }
        public void OnActionExecuted(ActionExecutedContext context)
        {
            //获取返回结果
            var result = Newtonsoft.Json.JsonConvert.SerializeObject(context.Result);
            //获取路由中的controller
            var controllerName = context.HttpContext.GetRouteValue("controller");
            //获取路由中的action
            var actionName = context.HttpContext.GetRouteValue("action");
            _ILogger.LogInformation($"执行{controllerName}控制器{actionName}方法:执行结果为:{result}");
        }
    }
controller代码如下:
public class FirstController : Controller
    {
        private readonly ILogger<FirstController> _Logger;
        private readonly ILoggerFactory _LoggerFactory;
        public FirstController(ILogger<FirstController> logger) {
            this._Logger = logger;
            this._Logger.LogInformation($"{this.GetType().Name}被构造了");
        }
        [TypeFilter(typeof(CustomLogActionFilterAttribute))]
        //[ServiceFilter(typeof(CustomLogActionFilterAttribute))]
        public IActionResult Index(int id)
        {
            ViewBag.user = Newtonsoft.Json.JsonConvert.SerializeObject(new {
                Id=id,
                Name = "Guandebao--ViewBag",
                Age=34
            });
            ViewData["UserInfo"] = Newtonsoft.Json.JsonConvert.SerializeObject(new
            {
                Id = id,
                Name = "Guandebao--ViewData",
                Age = 34
            });
            object description = "欢迎大家";
            this._Logger.LogInformation($"index被执行了");
            return View(description);
        }
    }
通过/First/Index?id=123访问测试以上代码,执行顺序如下:CustomLogActionFilterAttribute类的构造方法》FirstController构造方法》OnActionExecuting方法》Index Action方法》OnResourceExecuted方法。
OnActionExecuted代码中var result = Newtonsoft.Json.JsonConvert.SerializeObject(context.Result);返回结果如下:
{"StatusCode":null,"ViewName":null,"Model":"欢迎大家","ViewData":{"user":"{\"Id\":123,\"Name\":\"Guandebao--ViewBag\",\"Age\":34}","UserInfo":"{\"Id\":123,\"Name\":\"Guandebao--ViewData\",\"Age\":34}"},"TempData":{},"ViewEngine":null,"ContentType":null}
最后写入日志内容如下,写入日志文章介绍见(.net 6中使用log4net写文本日志):
2022-08-04 09:17:23,736 [74] INFO  TestCore.Controllers.FirstController - FirstController被构造了
2022-08-04 09:17:24,313 [74] INFO  TestCore.Utility.Filters.CustomLogActionFilterAttribute - 执行First控制器Index方法:参数为:?id=123
2022-08-04 09:17:24,946 [74] INFO  TestCore.Controllers.FirstController - index被执行了
2022-08-04 09:17:25,641 [74] INFO  TestCore.Utility.Filters.CustomLogActionFilterAttribute - 执行First控制器Index方法:执行结果为:{"StatusCode":null,"ViewName":null,"Model":"欢迎大家","ViewData":{"user":"{\"Id\":123,\"Name\":\"Guandebao--ViewBag\",\"Age\":34}","UserInfo":"{\"Id\":123,\"Name\":\"Guandebao--ViewData\",\"Age\":34}"},"TempData":{},"ViewEngine":null,"ContentType":null}
- .Nuget Packages 太占C盘,删除后可以放到其他盘(1623)
 - net core+webapi+nginx windows 服务器部署(1491)
 - ASP.NET Core 配置 Swagger 显示接口注释描述信息(1237)
 - .net core 6.0 web API + SwaggerUI + IIS部署(1188)
 - vue调用接口后获取不到后端返回的Header响应头(1180)
 - .net core 系列实例开发教程-权限管理系统功能介绍(1106)
 - .net core 实例教程(十二)配置启用Swagger中的【Authorize】按钮(1072)
 - .net core 实例教程(十一)生成JWT格式的token密码配置及代码(998)
 - .net core 实例教程(十四)配置 Swagger 显示接口注释描述信息及支持版本控制(964)
 - .net core 实例教程(三)仓储及领域服务功能实现(既实现用户表的增删改查接口)(947)
 
- 2025年3月 (1)
 - 2024年6月 (2)
 - 2024年5月 (2)
 - 2024年4月 (4)
 - 2024年3月 (30)
 - 2024年1月 (4)
 - 2023年12月 (2)
 - 2023年11月 (4)
 - 2023年10月 (4)
 - 2023年9月 (6)
 - 2023年3月 (2)
 - 2023年2月 (1)
 - 2023年1月 (1)
 - 2022年12月 (1)
 - 2022年9月 (21)
 - 2022年8月 (10)
 - 2022年7月 (3)
 - 2022年4月 (1)
 - 2022年3月 (13)
 - 2021年8月 (1)
 - 2021年3月 (1)
 - 2020年12月 (42)
 - 2020年11月 (7)
 - 2020年10月 (5)
 - 2020年8月 (1)
 - 2020年6月 (1)
 - 2020年3月 (2)
 - 2019年12月 (8)
 - 2019年11月 (3)
 - 2019年9月 (1)
 - 2019年4月 (1)
 - 2019年3月 (6)
 - 2019年2月 (1)
 - 2018年7月 (7)
 
- 1.asp.net mvc内微信pc端、H5、JsApi支付方式总结(5880)
 - 2.Windows 10休眠文件更改存储位置(3836)
 - 3.各大搜索网站网站收录提交入口地址(3481)
 - 4.ECharts仪表盘实例及参数使用详解(3434)
 - 5.windows 10安装myeclipse 10破解补丁cracker.jar、run.bat闪退解决办法(3425)
 - 6.HTML5 WebSocket与C#建立Socket连接实现代码(3181)
 - 7.华为鸿蒙系统清除微信浏览器缓存方法(3177)
 - 8.CERT_HAS_EXPIRED错误如何解决(2969)
 - 9.Js异步async、await关键字详细介绍(lambda表达式中使用async和await关键字)(2608)
 - 10.HBuilder编辑器格式化代码(2395)
 
    