ASP.NET 5 中的全局异常处理
Global exception handling in ASP.NET 5
如何将我自己的日志记录逻辑附加到 ASP.NET 5 应用程序以处理业务逻辑和较低层中抛出的每个异常?
我在 Startup.cs 中尝试了自己的 ILoggerProvider
实现和 loggerfactory.AddProvider(new LoggerProvider(Configuration))
。但它似乎拦截了内部 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());
}
但是上面的这个选项,似乎只在 MVC 特定事件、路由相关等上调用 ILogger 的 Write 函数,当我在较低层抛出异常时它没有被调用,所以第二个选项有效输出:
2) 全局过滤器
在 Startup.cs:
中注册您自己的 ActionFilterAttribute 实现
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc().Configure<MvcOptions>(options =>
{
options.Filters.Add(new YourCustomFilter());
});
}
重要的是,自定义过滤器 class 实现了 IExceptionFilter 接口:
public class YourCustomFilter : ActionFilterAttribute, IExceptionFilter
{
public void OnException(ExceptionContext context)
{
///logic...
}
}
(编辑:)
然后在 Startup class 我们添加过滤器:
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc(options =>
{
options.Filters.Add(new YourCustomFilter());
});
}
如果您想要一个真正的全局异常陷阱框架,而不仅仅是在控制器级别,请查看我的一个开源项目。我计划在假期后不久将其制作成 Nuget 包。我还计划更新我的博客,展示我开发它的原因。
开源项目在github:
https://github.com/aspnet-plus/AspNet.Plus.Infrastructure
查看使用示例。
如何将我自己的日志记录逻辑附加到 ASP.NET 5 应用程序以处理业务逻辑和较低层中抛出的每个异常?
我在 Startup.cs 中尝试了自己的 ILoggerProvider
实现和 loggerfactory.AddProvider(new LoggerProvider(Configuration))
。但它似乎拦截了内部 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());
}
但是上面的这个选项,似乎只在 MVC 特定事件、路由相关等上调用 ILogger 的 Write 函数,当我在较低层抛出异常时它没有被调用,所以第二个选项有效输出:
2) 全局过滤器 在 Startup.cs:
中注册您自己的 ActionFilterAttribute 实现public void ConfigureServices(IServiceCollection services)
{
services.AddMvc().Configure<MvcOptions>(options =>
{
options.Filters.Add(new YourCustomFilter());
});
}
重要的是,自定义过滤器 class 实现了 IExceptionFilter 接口:
public class YourCustomFilter : ActionFilterAttribute, IExceptionFilter
{
public void OnException(ExceptionContext context)
{
///logic...
}
}
(编辑:) 然后在 Startup class 我们添加过滤器:
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc(options =>
{
options.Filters.Add(new YourCustomFilter());
});
}
如果您想要一个真正的全局异常陷阱框架,而不仅仅是在控制器级别,请查看我的一个开源项目。我计划在假期后不久将其制作成 Nuget 包。我还计划更新我的博客,展示我开发它的原因。
开源项目在github: https://github.com/aspnet-plus/AspNet.Plus.Infrastructure 查看使用示例。