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 public void Configure(IApplicationBuilder app,IHostingEnvironment env,ILoggerFactory loggerfactory) { loggerfactory.AddProvider(new YourCustomProvider()); } 但是上面这个选项,似乎只调用了ILogger的写函数对MVC的具体事件,路由相关等等,当我在我的下层上抛出异常时,没有被调用,所以第二个选项是: 2)全局过滤器 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()); }); } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
- asp.net – System.Web.UI.ViewStateException,无
- ASP.NET AJAX(9)-ScriptManagerProxy
- asp.net-mvc-3 – 设置表级别WillCascadeOnDelet
- asp.net-mvc – StackExchange.Redis.IDatabase存
- asp.net-mvc – 为服务层设计DI(构造函数注入)的
- asp.net – Response.IsClientConnected如何在幕
- 让 .NET 轻松构建中间件模式代码
- ADO.NET实用经验 转载
- asp.net-mvc – 在Generic Repository中定义Defa
- ASP.NET Core&EntityFramework核心:左(外)加
热点阅读