- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
正如我们所知,例如What is the difference between customErrors and httpErrors? , CustomErrors是在 Web 应用程序中定义错误页面的较旧方法,但这种方法有一些问题 - 例如,如果您关心正确的 http 响应代码,因为 CustomErrors 的方法是重定向到错误页面而不是替换当前响应,这会破坏大多数通信的语义完整性是通过 http 状态代码实现的。
HttpErrors是自 IIS 7.0 以来提供的一项新功能,它在服务器级别而不是应用程序级别上运行,并且更适合以有效的方式处理错误响应,例如通过使用当前响应而不是重定向。
但是,在我看来,ASP.NET 中这些工件的基础结构目前看来给我们带来了一些问题。
简单配置示例
<httpErrors existingResponse="Auto" errorMode="Custom">
<remove statusCode="404"/>
<error statusCode="404" path="/Error/E404" responseMode="ExecuteURL" />
</httpErrors>
我们将errorMode设置为自定义,因为我们想测试错误处理本身,并将existingResponse设置为自动 em>,这将引入一个依赖于 Response.TrySkipIisCustomErrors 的分支:
理想情况下,这将允许我们自己处理一些错误,例如当 ../product/id 中的产品不存在时,我们可以手动返回包含有关缺失产品的信息的特定 404 页面,但仍然让 HttpErrors 模块处理所有其余内容,例如 ../products/namebutshouldbeid 或只是 ../misspelledandunmatchableurl。
但是,据我所知,这不起作用。原因在于内部方法 System.Web.HttpResponse .ReportRuntimeError,它将在运行时错误(例如未找到 Controller /操作)时调用,并且我们有一个如下所示的部分:
// always try to disable IIS custom errors when we send an error
if (_wr != null) {
_wr.TrySkipIisCustomErrors = true;
}
if (!localExecute) {
code = HttpException.GetHttpCodeForException(e);
// Don't raise event for 404. See VSWhidbey 124147.
if (code != 404) {
WebBaseEvent.RaiseRuntimeError(e, this);
}
// This cannot use the HttpContext.IsCustomErrorEnabled property, since it must call
// GetSettings() with the canThrow parameter.
customErrorsSetting = CustomErrorsSection.GetSettings(_context, canThrow);
if (customErrorsSetting != null)
useCustomErrors = customErrorsSetting.CustomErrorsEnabled(Request);
else
useCustomErrors = true;
}
第一次调试时,我看到 useCustomErrors 设置为 false,我无法理解为什么,因为我知道我有一个有效的 HttpError 配置,因为它有效我返回 HttpNotFoundResult来自 Controller 。
然后我意识到这不是 HttpErrors,而是较旧的 CustomErrors。而且 CustomErrors 显然不知道 HttpErrors。
“错误”
所以发生的事情是 Response.TrySkipIisCustomErrors设置为 true 并且由于没有定义 CustomErrors,因此它返回详细的 404 响应。此时,我们希望 HttpErrors 启动,但它不会启动,因为 TrySkipIisCustomErrors 现在设置为 true。
我们也不能使用 CustomErrors,因为这会让我们回到令人反感的错误重定向问题。
以及返回HttpNotFoundResult的原因之所以有效,是因为它不会触发运行时错误,只会返回 404 结果,HttpErrors 会按预期拦截,只要我们避免设置 Response.TrySkipIisCustomErrors为真。
应该/如何处理/解决这个问题?
我认为 System.Web.HttpResponse .ReportRuntimeError 不应被允许设置 Response.TrySkipIisCustomErrors默认情况下为 true,因为我们有另一个依赖于此的错误处理模块。因此,此方法需要了解任何 HttpErrors配置,或者通过避免将 TrySkipIisCustomErrors 设置为 true(如果我们有任何 CustomErrors)配置,或者它处理 HttpErrors 配置以及 CustomErrors 配置。
或者我错过了一些 secret 魔法来解决这个问题?
最佳答案
我已经努力解决这个问题好几天了,我认为唯一有效的解决方案是发布的 here (Starain chen 对 @Alex 在 forums.asp.net 上发布的同一问题的回答):
(我稍微修改了代码)
public class CustomHandleErrorAttribute : HandleErrorAttribute {
public override void OnException (ExceptionContext filterContext) {
if (filterContext.ExceptionHandled) {
return;
}
var httpException = new HttpException(null, filterContext.Exception);
var httpStatusCode = httpException.GetHttpCode();
switch ((HttpStatusCode) httpStatusCode) {
case HttpStatusCode.Forbidden:
case HttpStatusCode.NotFound:
case HttpStatusCode.InternalServerError:
break;
default:
return;
}
if (!ExceptionType.IsInstanceOfType(filterContext.Exception)) {
return;
}
// if the request is AJAX return JSON else view.
if (filterContext.HttpContext.Request.Headers["X-Requested-With"] == "XMLHttpRequest") {
filterContext.Result = new JsonResult {
JsonRequestBehavior = JsonRequestBehavior.AllowGet,
Data = new {
error = true,
message = filterContext.Exception.Message
}
};
}
else {
var controllerName = (String) filterContext.RouteData.Values["controller"];
var actionName = (String) filterContext.RouteData.Values["action"];
var model = new HandleErrorInfo(filterContext.Exception, controllerName, actionName);
filterContext.Result = new ViewResult {
ViewName = String.Format("~/Views/Hata/{0}.cshtml", httpStatusCode),
ViewData = new ViewDataDictionary(model),
TempData = filterContext.Controller.TempData
};
}
// TODO: Log the error by using your own method
filterContext.ExceptionHandled = true;
filterContext.HttpContext.Response.Clear();
filterContext.HttpContext.Response.StatusCode = httpStatusCode;
filterContext.HttpContext.Response.TrySkipIisCustomErrors = true;
}
}
App_Start/FilterConfig.cs
中使用此自定义处理错误属性public class FilterConfig {
public static void RegisterGlobalFilters (GlobalFilterCollection filters) {
filters.Add(new CustomHandleErrorAttribute());
}
}
Global.asax
中剩余的异常protected void Application_Error () {
var exception = Server.GetLastError();
var httpException = exception as HttpException ?? new HttpException((Int32) HttpStatusCode.InternalServerError, "Internal Server Error", exception);
var httpStatusCode = httpException.GetHttpCode();
Response.Clear();
var routeData = new RouteData();
routeData.Values.Add("Controller", "Error");
routeData.Values.Add("fromAppErrorEvent", true);
routeData.Values.Add("ErrorMessage", httpException.Message);
routeData.Values.Add("HttpStatusCode", httpStatusCode);
switch ((HttpStatusCode) httpStatusCode) {
case HttpStatusCode.Forbidden:
case HttpStatusCode.NotFound:
case HttpStatusCode.InternalServerError:
routeData.Values.Add("action", httpStatusCode.ToString());
break;
default:
routeData.Values.Add("action", "General");
break;
}
Server.ClearError();
IController controller = new Controllers.ErrorController();
// TODO: Log the error if you like
controller.Execute(new RequestContext(new HttpContextWrapper(Context), routeData));
}
ErrorController
[AllowAnonymous]
public class ErrorController : Controller {
protected override void OnActionExecuting (ActionExecutingContext filterContext) {
base.OnActionExecuting(filterContext);
var errorMessage = RouteData.Values["ErrorMessage"];
var httpStatusCode = RouteData.Values["HttpStatusCode"];
if (errorMessage != null) {
ViewBag.ErrorMessage = (String) errorMessage;
}
if (httpStatusCode != null) {
ViewBag.HttpStatusCode = Response.StatusCode = (Int32) httpStatusCode;
}
Response.TrySkipIisCustomErrors = true;
}
[ActionName("403")]
public ActionResult Error403 () {
return View();
}
[ActionName("404")]
public ActionResult Error404 () {
return View();
}
[ActionName("500")]
public ActionResult Error500 () {
return View();
}
public ActionResult General () {
return View();
}
}
为ErrorController
中的操作创建 View 。 (403.cshtml
、404.cshtml
、500.cshtml
和 General.cshtml
)
200 OK
:如果我导航到 /error/404<,我希望得到 200 OK
/
。ViewBag.ErrorMessage
)关于asp.net - CustomErrors 与 HttpErrors - 一个重大的设计缺陷?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24465261/
本篇参考: https://help.salesforce.com/s/articleView?id=sf.flow_ref_elements_custom_error.htm&ty
我想使用 catchError 将我的错误返回为自定义类型。起初,我希望我的网络层返回 Observable,然后在 ViewModel 中我为它订阅了 .OnNext、.OnError、.OnCom
我目前有 httpErrors在此处设置以处理 500:- ...... 这工作正常,但在 iis 收到错误的情况下,我仍然会看到蓝屏死机。一个
是否可以在 Web 应用程序运行时的代码中检查天气自定义错误是打开还是关闭。 最佳答案 我已经想出了如何去做它在... HttpContext.Current.IsCustomErrorEnabled
我已经将我的网页上传到服务器。 我的网页在本地系统中运行良好。但是当我将它上传到服务器时却显示错误 The configuration section 'customErrors' cannot be
当我尝试使用远程处理连接到我的服务器应用程序时出现以下错误: A problem seems to have occured whilst connecting to the remote serve
在我的 ASP.NET 网站的 web.config 中,我有 customErrors在 HTTP 404 的情况下,打开并设置为重定向到特定操作: 现在我启动 Fiddler 并在我的浏览器中查询
我创建了一个 asp.net 网页并将其上传到网络服务器上。但是,当我尝试远程查看页面时,我收到有关 web.config 文件中 customerror 标记的错误。该页面在本地工作,没有错误或警告
我有asp.net mvc 3应用程序。 当用户传递不存在的对象的ID时,我以这种方式返回404 View : Response.StatusCode = 404; return View("404"
我有一台机器上的 8080 端口上运行的 ASP.NET 服务器,出于性能原因,一个 nginx 缓存反向代理在端口 80 上运行。请求会发送到端口 80,然后,如果 nginx 缓存没有响应,则将其
这是做什么用的? ASP.NET 错误提示我必须将其放入我的 web.config 文件中。这些代码行是做什么的? 最佳答案 您可以阅读有关 的信息元素 here on MSDN .
为什么我的 typescript 引用我的自定义错误给我错误 Argument of type CustomError is not assignable to parameter of type E
来自 msdn站点,我知道 customErrors 元素提供有关 ASP.NET 应用程序的自定义错误消息的信息。 mode 属性的 RemoteOnly 值指定自定义错误仅显示给远程客户端,而 A
在旧站点中,我通过添加 redirectMode="ResponseRewrite" 来更改 CustomErrors 的工作方式(3.5 SP1 中的新增功能): 问题是:它向我显示了
ASP.NET MVC 应用程序中 web.config 文件的 customErrors 和 httpErrors 部分有什么区别? 每个部分的使用指南是什么? 最佳答案 *2016 年 4 月更新
我有这样的 web.config 设置 以及httperrors
正如我们所知,例如What is the difference between customErrors and httpErrors? , CustomErrors是在 Web 应用程序中定义错误页
我只想做如下事情: var defaultRedirectUrl = SomeMethodToGetDefaultRedirect(); 当然在 web.config 中我有 如何做到这一点? 最佳
摘要 customErrors也经常在开发部署中看到<customErrors mode="Off" />,设置这样可以在页面上看到详细的错误信息。但也为黑客提供了
我更改了以下 web.config: 1- VirtualDirectory\80\web.config 2- 14\TEMPLATE\LAYOUTS\web.config 3- 14\TEMPLAT
我是一名优秀的程序员,十分优秀!