菜的像徐坤
排名
6
文章
6
粉丝
16
评论
8
{{item.articleTitle}}
{{item.blogName}} : {{item.content}}
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术

.NET CORE 全局异常抓取

5719人阅读 2022/11/3 15:07 总访问:899930 评论:0 收藏:0 手机
分类: 工作积累

前言

全局异常处理在工作中肯定会遇到相关问题,今天就碰到了一个异常处理的问题,异常过滤器IExceptionFilter的局限性问题,在过滤器中发生的异常并不会被捕捉


MVC异常过滤器(限制范围Action)

异常过滤器IExceptionFilter (  A filter that runs after an action has thrown an System.Exception.),顾,它抓取的范围是Action方法执行过程中出现的未处理的异常,其它异常并不会被该过滤器捕捉到,如身份验证器中的异常,所以用IExceptionFilter做全局异常抓取是有很大局限性的

UseExceptionHandler中间件

在Configure中注册UseExceptionHandler处理全局未处理异常,该模块可分成两部分,1.开发环境(可打印详细异常) 2.生产环境(返回自定义数据),具体实现如下

public void Configure(IApplicationBuilder app, IHostingEnvironment env, IServiceProvider svp)
{
if (env.IsDevelopment())
{
app.UseDeveloperExceptionPage();
}
else
{
app.UseExceptionHandler(builder => builder.Run(async context => await ErrorEvent(context)));
}
}
public Task ErrorEvent(HttpContext context)
{
     var feature = context.Features.Get<IExceptionHandlerFeature>();
            var error = feature?.Error;
            var guid = DateTime.Now.ToString("yyyyMMddHHmmssfff");
            var errorMessage = error.Message
            LogHelper.Error(errorMessage, error, "sys_log"); 

            return context.Response.WriteAsync(errorMessage);
}

通过这个中间件可以捕捉到 过滤器捕捉不到的异常
注意:如果这两个异常捕捉同时存在,异常处理后需要将异常标记为已解决( context.ExceptionHandled = true;)

评价