加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

ASP.NET 5中的全局异常处理

发布时间:2020-12-15 23:54:40 所属栏目:asp.Net 来源:网络整理
导读:如何将自己的日志逻辑附加到ASP.NET 5应用程序来处理业务逻辑和下层中抛出的每个异常? 我在Startup.cs中尝试使用自己的ILoggerProvider实现和loggerfactory.AddProvider(新的LoggerProvider(配置)).但是它似乎拦截了内部ASP.NET的东西,而不是我在较低层中抛
如何将自己的日志逻辑附加到ASP.NET 5应用程序来处理业务逻辑和下层中抛出的每个异常?

我在Startup.cs中尝试使用自己的ILoggerProvider实现和loggerfactory.AddProvider(新的LoggerProvider(配置)).但是它似乎拦截了内部ASP.NET的东西,而不是我在较低层中抛出的异常.

解决方法

通过使用两个选项:

1)ILoggerProvider
从命名空间Microsoft.Framework.Logging中实现自己的ILoggerProvider和ILogger然后将其附加到Startup.cs中的MVC框架中,添加以下代码:

public void Configure(IApplicationBuilder app,IHostingEnvironment env,ILoggerFactory loggerfactory)
 {
        loggerfactory.AddProvider(new YourCustomProvider());
 }

但是上面这个选项,似乎只调用了ILogger的写函数对MVC的具体事件,路由相关等等,当我在我的下层上抛出异常时,没有被调用,所以第二个选项是:

2)全局过滤器
在Startup.cs中注册自己的ActionFilterAttribute实现:

public void ConfigureServices(IServiceCollection services)
{
    services.AddMvc().Configure<MvcOptions>(options =>
    {
        options.Filters.Add(new YourCustomFilter());
    });
}

重要的是,自定义过滤器类实现了IExceptionFilter间隔:

public class YourCustomFilter : ActionFilterAttribute,IExceptionFilter
  {
             public void OnException(ExceptionContext context)
             {
              ///logic...
             }
 }

(编辑:)
然后在启动类中,我们添加过滤器:

public void ConfigureServices(IServiceCollection services)
    {
         services.AddMvc(options =>
            {
                options.Filters.Add(new YourCustomFilter());
            });
    }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读