如何将自己的日志逻辑附加到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()); }); }