ale*_*zyk 15 asp.net asp.net-core
如何将自己的日志记录逻辑附加到ASP.NET 5应用程序以处理业务逻辑和较低层中引发的每个异常?
我尝试了自己的ILoggerProvider
实现和 loggerfactory.AddProvider(new LoggerProvider(Configuration))
Startup.cs.但似乎它拦截了内部的ASP.NET内容,而不是我在较低层中引发的异常.
ale*_*zyk 10
通过使用两个选项完成了它:
1)ILoggerProvider从命名空间Microsoft.Framework.Logging实现自己的ILoggerProvider和ILogger然后将它附加到Startup.cs中的MVC框架中添加以下代码:
public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerfactory)
{
loggerfactory.AddProvider(new YourCustomProvider());
}
Run Code Online (Sandbox Code Playgroud)
但是上面这个选项,似乎只调用ILogger的Write函数对MVC特定事件,路由相关等等,当我在我的较低层上抛出异常时没有调用它,所以第二个选项解决了:
2)全局过滤器在Startup.cs中注册您自己的ActionFilterAttribute实现:
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc().Configure<MvcOptions>(options =>
{
options.Filters.Add(new YourCustomFilter());
});
}
Run Code Online (Sandbox Code Playgroud)
重要的是,自定义过滤器类实现IExceptionFilter interace:
public class YourCustomFilter : ActionFilterAttribute, IExceptionFilter
{
public void OnException(ExceptionContext context)
{
///logic...
}
}
Run Code Online (Sandbox Code Playgroud)
(编辑:)然后在Startup类中我们添加过滤器:
public void ConfigureServices(IServiceCollection services)
{
services.AddMvc(options =>
{
options.Filters.Add(new YourCustomFilter());
});
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
6010 次 |
最近记录: |