首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >ASP.NET 5中的全局异常处理

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

Stack Overflow用户
提问于 2015-02-07 18:38:35
回答 2查看 6.5K关注 0票数 15

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

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

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-02-14 01:56:41

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

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

代码语言:javascript
运行
复制
 public void Configure(IApplicationBuilder app, IHostingEnvironment env, ILoggerFactory loggerfactory)
 {
        loggerfactory.AddProvider(new YourCustomProvider());
 }

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

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

代码语言:javascript
运行
复制
public void ConfigureServices(IServiceCollection services)
{
    services.AddMvc().Configure<MvcOptions>(options =>
    {
        options.Filters.Add(new YourCustomFilter());
    });
}

重要的是,自定义筛选器类实现IExceptionFilter interace:

代码语言:javascript
运行
复制
  public class YourCustomFilter : ActionFilterAttribute, IExceptionFilter
  {
             public void OnException(ExceptionContext context)
             {
              ///logic...
             }
 }

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

代码语言:javascript
运行
复制
    public void ConfigureServices(IServiceCollection services)
    {
         services.AddMvc(options =>
            {
                options.Filters.Add(new YourCustomFilter());
            });
    }
票数 10
EN

Stack Overflow用户

发布于 2015-12-21 19:44:39

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

开放源码项目位于github:https://github.com/aspnet-plus/AspNet.Plus.Infrastructure上,请查看示例以供使用。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28385889

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档