asp.net-mvc – 将Elmah与WebApi一起使用时会记录两次错误

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – 将Elmah与WebApi一起使用时会记录两次错误前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试使用elmah从我的asp.net web api项目中记录异常.我有一个问题,每个错误被记录两次.

我正在使用Elmah.Contrib.Web-Api和我的Application类如下:

public class WebApiApplication : System.Web.HttpApplication
{
    protected void Application_Start()
    {
        GlobalConfiguration.Configuration.Filters.Add(new ElmahHandleErrorApiAttribute());

        RouteTable.Routes.MapHubs();
        RouteConfig.RegisterRoutes(RouteTable.Routes);

#if DEBUG
        EntityFrameworkProfiler.Initialize();
#endif

        GlobalConfig.CustomizeConfig(GlobalConfiguration.Configuration);

    }
}

如果我提出以下行,那么我根本就没有消息:

GlobalConfiguration.Configuration.Filters.Add(new ElmahHandleErrorApiAttribute());

我可以确认我只抛出一个错误,生成错误调用只被调用一次,而且我没有用Elmah属性手动修饰我的控制器或方法.

为了尝试解决这个问题,我删除了Contrib包并添加了按照此处的说明http://www.tugberkugurlu.com/archive/asp-net-web-api-and-elmah-integration

这没有解决问题,它仍然记录两次.它确实允许我在Attribute类中加入一个断点,并确认每次错误都会被调用两次.

我怎么解决这个问题?

解决方法

您的web.config中有哪些与ELMAH相关的条目?

我在MVC应用程序中遇到了类似的问题 – 处理的异常被记录了两次.在应用程序中,我使用自定义异常过滤器使用错误信号将处理的异常记录到ELMAH,而HTTP模块负责处理未处理的异常.

原来我需要设置:

<add key="elmah.mvc.disableHandleErrorFilter" value="true" />

在web.config中,以禁用ELMAH.MVC NuGet包中的内置异常过滤器.

内置过滤器的源代码显示它记录处理的异常:
https://github.com/alexanderbeletsky/elmah-mvc/blob/master/src/Elmah.Mvc/HandleErrorAttribute.cs

猜你在找的asp.Net相关文章