37

我花了很多时间试图找出解决方法无济于事,所以我想我会看看这里是否有人有想法。

在我的 ASP.NET MVC3 应用程序中使用 Elmah。我正在使用与上一个链接中接受的答案完全相同的代码。

我的 Global.asax 中也有这段代码,用于显示带有正确 HTTP 响应的错误页面:

    /// <summary>
    /// The customErrors functionality provided by ASP.NET results in HTTP 302 redirects occurring which doesn't accurately reflect what the real HTTP code of the response was.
    /// This method can be used to handle specific HTTP codes without an intermediate redirect.
    /// </summary>
    protected void Application_Error() {
        var exception = Server.GetLastError();
        var httpException = exception as HttpException;
        Response.Clear();
        Server.ClearError();
        var routeData = new RouteData();
        routeData.Values["controller"] = "Error";
        routeData.Values["action"] = "Error500";
        Response.StatusCode = 500;

        if (httpException != null) {
            Response.StatusCode = httpException.GetHttpCode();
            Response.TrySkipIisCustomErrors = true;
            switch (Response.StatusCode) {
                case 403:
                    routeData.Values["action"] = "Error403";
                    break;
                case 404:
                    routeData.Values["action"] = "Error404";
                    routeData.Values["message"] = httpException.Message;
                    break;
                case 500:
                    routeData.Values["action"] = "Error500";
                    break;
            }
        }

        IController errorsController = new ErrorController();
        var rc = new RequestContext(new HttpContextWrapper(Context), routeData);
        errorsController.Execute(rc);
    }

当我不在我的(本地)开发机器上时会出现问题(最初让我认为它与customErrors相关)。当抛出异常时,Elmah 会处理错误并正确记录它。我也最终出现在正确的错误页面上。但是,在到达正确的错误页面之前,我可以看到另一个中间异常被记录:

The view 'Error' or its master was not found or no view engine supports the searched locations. The following locations were searched: ~/Views/Articles/Error.aspx ~/Views/Articles/Error.ascx ~/Views/Shared/Error.aspx ~/Views/Shared/Error.ascx ~/Views/Articles/Error.cshtml ~/Views/Articles/Error.vbhtml ~/Views/Shared/Error.cshtml ~/Views/Shared/Error.vbhtml

ASP.NET 正在尝试加载默认错误页面,即使我正在尝试处理它。有人对如何防止这种情况有任何想法吗?

4

5 回答 5

32

不要base.OnException(context);在您的自定义错误处理程序中调用从HandleErrorAttribute. 您不再需要它,因为您已经在Application_Error.

于 2012-04-18T06:25:36.687 回答
17

我遇到了同样的问题,但我没有在任何地方执行 base.OnException() 。另一种可能的解决方案是从<system.web>我的 web.config 中删除它:

<customErrors mode="On" />
于 2013-10-01T16:07:54.753 回答
4

如果您使用 Elmah.MVC 并想使用自定义错误页面,只需在您的 Web.config 中将以下值更改为 true:

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

这将保持 Elmah 日志记录处于启用状态,但阻止它尝试重定向到默认错误页面。

于 2018-04-13T18:32:37.807 回答
3

您的网站试图导航到 ~/Error 的某个地方,但由于它不存在而找不到它。

尝试在 Web.config 中删除或禁用customErrors 。我愿意将其设置为默认值重定向到~/Error

如果您想发布您的 Web.config(省略任何敏感信息),我可能会提供帮助。我最近和 Elmah 处理过类似的问题。

于 2012-04-17T21:39:32.733 回答
1

如果您使用 Elmah.mvc,那么将这个设置更改为 true 会有所帮助:

<add key="elmah.mvc.disableHandler" value="true" />
<add key="elmah.mvc.disableHandleErrorFilter" value="true" />
于 2018-01-11T11:26:47.353 回答