我一直在努力让自定义错误页面正常工作,并继续寻找简单使用静态页面的方法。虽然静态页面有效,但它需要重新构建我们希望在此时避免的导航栏。我目前正在使用以下内容指定自定义错误页面。
Asp.net错误处理
<httpErrors errorMode="Custom">
<remove statusCode="404"/>
<error statusCode="404" path="/404.html" responseMode="File"/>
</httpErrors>
IIS错误处理
\d{4}-\d{6}
是否有实现动态自定义错误页面的方法可以处理IIS错误和Asp.net错误?
答案 0 :(得分:5)
我也在努力解决这个问题并且搜索了很长时间。据我所知,没有办法创建一个动态自定义错误页面,为未进入.net管道的请求的IIS错误提供服务。和你一样,我最终有两个404错误页面。一个动态.aspx用于文件未找到由于进入.net管道的请求而导致的错误,一个.html用于未找到从未进入.net管道的文件未找到的请求。贬低你的问题的人可能并没有意识到你提出了一个非常好的,也是一个难以解决的问题。我会提出你的问题来帮助补偿。
答案 1 :(得分:1)
我在ASP.Net MVC项目中解决了同样的问题,通过处理程序将所有内容通过.Net进行管道传输。
<system.webServer>
<handlers>
<remove name="ExtensionlessUrlHandler-ISAPI-4.0_32bit" />
<remove name="ExtensionlessUrlHandler-ISAPI-4.0_64bit" />
<remove name="ExtensionlessUrlHandler-Integrated-4.0" />
<remove name="OPTIONSVerbHandler" />
<remove name="TRACEVerbHandler" />
<add name="ExtensionlessUrlHandler-ISAPI-4.0_32bit" path="*.*" verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS" modules="IsapiModule" scriptProcessor="%windir%\Microsoft.NET\Framework\v4.0.30319\aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness32" responseBufferLimit="0" />
<add name="ExtensionlessUrlHandler-ISAPI-4.0_64bit" path="*.*" verb="GET,HEAD,POST,DEBUG,PUT,DELETE,PATCH,OPTIONS" modules="IsapiModule" scriptProcessor="%windir%\Microsoft.NET\Framework64\v4.0.30319\aspnet_isapi.dll" preCondition="classicMode,runtimeVersionv4.0,bitness64" responseBufferLimit="0" />
<add name="ExtensionlessUrlHandler-Integrated-4.0" path="*.*" verb="GET,HEAD,POST,DEBUG,PUT,DELETE" type="System.Web.Handlers.TransferRequestHandler" preCondition="integratedMode,runtimeVersionv4.0" />
</handlers>
</system.webServer>
首先创建ErrorController
来处理请求错误,而不是找到像。
[AllowAnonymous]
public class ErrorController : Controller {
// GET: Error
public ActionResult NotFound() {
Response.StatusCode = (int)System.Net.HttpStatusCode.NotFound;
Response.TrySkipIisCustomErrors = true;
HttpContext.Response.StatusCode = (int)System.Net.HttpStatusCode.NotFound;
HttpContext.Response.TrySkipIisCustomErrors = true;
return View();
}
public ActionResult Error() {
Response.StatusCode = (int)System.Net.HttpStatusCode.InternalServerError;
Response.TrySkipIisCustomErrors = true;
return View();
}
}
您会注意到我致电TrySkipIisCustomErrors
以尝试避免IIS错误
然后创建一个基本控制器来处理将映射到ErrorController.NotFound
操作的所有未知操作。
public abstract class FrontOfficeControllerBase : Controller {
protected override void HandleUnknownAction(string actionName) {
var data = ViewData;
//Custom code to resolve the view.
//ViewResult view = this.View<ErrorController>(c => c.NotFound());
//Manually create view with view Data
ViewResult view = new ViewResult();
view.ViewData = new ViewDataDictionary();
view.ViewData["controller"] = "Error";
view.ViewData["action"] = "NotFound";
if (data != null && data.Count > 0) {
data.ToList().ForEach(view.ViewData.Add);
}
Response.StatusCode = (int)System.Net.HttpStatusCode.NotFound;
Response.TrySkipIisCustomErrors = true;
view.ExecuteResult(this.ControllerContext);
}
}
所有Controllers
都将从此基本控制器继承。
在所有其他路线之后配置了捕获所有路线。
routes.MapRoute(
name: "404-NotFound",
url: "NotFound",
defaults: new { controller = "Error", action = "NotFound" }
);
routes.MapRoute(
name: "500-Error",
url: "Error",
defaults: new { controller = "Error", action = "Error" }
);
routes.MapRoute(
name: "CatchAll",
url: "{*any}",
defaults: new { controller = "Error", action = "NotFound" });
这确保了如果路由与我的任何控制器都不匹配,它将安全地路由到ErrorController.NotFound
动作。
对于观看次数,我在NotFound.shtml
文件夹中创建了相应的Error.cshtml
和Views/Shared
页面,并且他们从访问根布局中获益,这是我认为您正在寻找的内容
最后,我能够从customErrors
删除httpErrors
和web.config
,因为不再需要它们,因为每个请求都由处理程序管理并相应地路由
这个结构的最初想法来自这篇文章,在这篇文章中我混合并匹配了可用的选项,直到我找到了一个适合我需要的解决方案。
Exception handling in ASP.NET MVC (6 methods explained)
希望这有帮助。