gpt4 book ai didi

ASP.NET MVC、自定义错误和响应重写

转载 作者:行者123 更新时间:2023-12-04 21:16:10 25 4
gpt4 key购买 nike

我有一个 MVC 网站(v5,虽然我不认为它是相关的),我在尝试建立数据库连接时故意引入了一个错误(连接字符串中的服务器 IP 错误)。当用户点击 HomeController 时,构造函数的一个依赖项是 UserRepository(用于获取当前用户配置文件数据),它依赖于可用的数据库连接/ session 。如果不是,则依赖解析器无法注入(inject) UserRepository,当这种情况发生时,它会导致错误(就像它与任何 Controller 的任何依赖一样),并且我得到一个通用的“没有为此对象定义的无参数构造函数”。这是非常没用的。

所以我尝试使用自定义错误页面来检索内部异常并以友好的方式显示它。 (因为在尝试获取 HomeController 时会发生此错误,它实际上从未到达 HandleErrorAttribute,因此依赖于 CustomErrors)。

所以我有一个带有一系列 Action 的 ErrorsController ......

来自 ErrorsComtroller.cs 的片段

public ActionResult Error()
{
return View("Error_500");
}

public ActionResult NotFound()
{
return View("Error_404");
}

来自 web.config 的片段
<customErrors mode="On">
<error statusCode="404" redirect="~/errors/notfound" />
<error statusCode="500" redirect="~/errors/error" />
</customErrors>

Error_500 页面非常基本,它的模型类型为 HandleErrorInfo ,但如果它不存在,它会使用 Server.GetLastError() 检查异常详细信息.问题是, GetLastError()始终为空,并且我得到了我的自定义错误页面,但除了“发生意外错误”的一般反馈之外,没有其他详细信息。在进行了一些挖掘之后,我发现该方法在重定向后不起作用,这是 CustomErrors 函数的默认方式。所以我改变了 web.config 来使用这条线......

来自 web.config 的片段


这样就不会导致重定向和 GetLastError()应该有我关于数据库连接问题的异常详细信息。问题是,现在我得到了带有此消息的默认 ASP.NET 错误页面。

An exception occurred while processing your request. Additionally, another exception occurred while executing the custom error page for the first exception. The request has been terminated.



因此,我使用 Intellitrace 进行了更多挖掘,我看到了有关数据库连接的异常。再往下一点,我看到关于在 HomeController 上没有无参数构造函数的错误,然后是关于在尝试创建类型为“HomeController”的 Controller 时遇到错误的错误。但后来我看到一个说

Error executing child request for /errors/error



所以我直接导航到该路径并且页面工作正常。但是当它与 ResponseRewrite 一起用于自定义错误时对于重定向模式,它会出错。我在 ErrorsController.Error() 的第一行(也是唯一一行)上放了一条折线。行动,但它永远不会被击中。如果我将自定义错误中的重定向路径替换为静态文件,它可以工作,但如果我将其更改回 ~/errors/error它再次失败。

ResponseRewrite 时使用 MVC 操作作为 CustomErrors 的 URL 时是否存在问题?指定?

最佳答案

“发生这种情况是因为“ResponseRewrite”模式在后台使用 Server.Transfer,它在文件系统上查找文件。因此,您需要将重定向路径更改为静态文件,例如更改为 .aspx 或 .html文件:”
<customErrors mode="On" redirectMode="ResponseRewrite" defaultRedirect="~/Error.aspx"/>
见:https://dusted.codes/demystifying-aspnet-mvc-5-error-pages-and-error-logging

“显然,Server.Transfer 与 MVC 路由不兼容,因此,如果您的错误页面由 Controller 操作提供,Server.Transfer 将查找/Error/Whatever,而不是在文件系统上找到它,并返回一个通用 404 错误页面!”

见:CustomErrors does not work when setting redirectMode="ResponseRewrite"

换句话说,您不能将 ResponseRewrite 与 View 一起使用。

这是一个众所周知的问题,对开发人员来说一直是个问题,因为它无法提供简单或优雅的解决方案。归根结底,当使用自定义 View 进行异常处理和使用客户友好页面处理 HTTP 错误时,MVC 表现不佳。 Views\Shared 文件夹中的 stock error.cshtml 文件(即一个 View )是一件很棒的事情,因为它维护了网页的布局并提供了异常错误。但是,当您收到 HTTP 错误时,您需要创建一个 View 来处理状态代码错误(例如,404、500 等)。注意:如果您将 HTTP 错误发送到 View ,则 URL 行将包含不理想的信息(请参阅下面的网络链接以获取更多说明)。

您可以将 HTTP 错误路由到错误 View ,但我不建议这样做,因为错误 View 应该用于应用程序错误(即异常),而应该为通用 HTTP 错误创建单独的自定义用户友好页面。不同之处在于前者是站点开发人员需要查看的应用程序问题,而后者是用户错误(或至少应该是),不需要开发人员查看它(只需我的 2 美分)。

另一种方法是绕过 View 并使用自定义的用户友好页面来处理应用程序异常和 HTTP 错误。但是,要注意两个问题:

1.) 返回错误的状态码(通常为 200),这可能是个问题,因为它会被搜索引擎提取和索引(你不希望这样!)

2.) URL 在网络浏览器中指定了一个无意义的 URL

这些可以很容易地处理。请参阅以下链接(转到 web.config 中的 customErrors 部分):https://dusted.codes/demystifying-aspnet-mvc-5-error-pages-and-error-logging

以下是我也发现有用的其他网络链接:

http://benfoster.io/blog/aspnet-mvc-custom-error-pages

https://msdn.microsoft.com/en-us/library/bb397417.aspx

https://www.youtube.com/watch?v=nNEjXCSnw6w

How do I display custom error pages in Asp.Net Mvc 3?

最后一个似乎是另一种选择:一种自定义 hack,以解决无法将 View 与 ResponseRewrite 耦合的问题。这可以通过完全绕过 CustomErrors(即 CustomErrors mode="Off")来实现。我还没有尝试过,但我正在研究它。

最后的想法,当抛出错误或异常代码时,请密切关注所有站点状态代码 - 确保没有 200(即,OK)代码。

关于ASP.NET MVC、自定义错误和响应重写,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23228051/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com