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

时间:2015-02-07 18:38:35

标签: asp.net asp.net-core

如何将自己的日志记录逻辑附加到ASP.NET 5应用程序来处理业务逻辑和较低层中抛出的每个异常?

我尝试在Startup.cs中使用自己的ILoggerProvider实现和loggerfactory.AddProvider(new LoggerProvider(Configuration))。但似乎它拦截了内部的ASP.NET内容,而不是我在较低层中引发的异常。

2 个答案:

答案 0 :(得分:10)

通过使用两个选项来解决这个问题:

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

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

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

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

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

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

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

(EDIT :) 然后在Startup类中添加过滤器:

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

答案 1 :(得分:2)

如果您想要一个真正的全局异常陷阱框架,而不仅仅是在控制器级别,请查看我的一个开源项目。我打算在假期后不久将它变成Nuget包。我还计划更新我的博客,说明我开发它的原因。

开源项目在github上: https://github.com/aspnet-plus/AspNet.Plus.Infrastructure 看看样本的使用情况。