微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

原文地址:https://www.jb51.cc/aspnet/248883.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐