我有一个webforms项目,我想记录Global.asax中的所有404错误,所以我把这段代码放在那里:
void Application_Error(object sender, EventArgs e)
{
var exception = Server.GetLastError();
var httpException = exception as HttpException;
if (httpException == null)
{
Log.Error(string.Format("Unkown error:", Request.Url.AbsoluteUri), exception);
}
else if (httpException.GetHttpCode() == 404)
{
Log.Warn(string.Format("RequestError 404: {0}", HttpContext.Current.Request.Url.AbsoluteUri));
}
else
{
Log.Error(string.Format("RequestError {0}: {2}\r\n{1}", httpException.GetHttpCode(), Server.UrlDecode(Request.Headers.ToString()), HttpContext.Current.Request.Url.AbsoluteUri), httpException);
}
}
这适用于扩展名为“.aspx”的所有请求。没有它或使用其他扩展名,Application_Error
被绕过。
这是我的web.config
<customErrors defaultRedirect="/500.aspx" mode="Off">
<error statusCode="404" redirect="/404.aspx"/>
<error statusCode="500" redirect="/500.aspx"/>
</customErrors>
有什么想法吗?
答案 0 :(得分:6)
Global.asax文件中定义的错误处理程序仅捕获ASP.NET运行时处理请求期间发生的错误。例如,如果用户请求您的应用程序中没有出现的.aspx文件,它将捕获错误。但是,如果用户请求不存在的.htm文件,它不会捕获错误。对于nonASP.NET错误,您可以在Internet信息服务(IIS)中创建自定义处理程序。也不会为服务器级错误调用自定义处理程序。
这是http://msdn.microsoft.com/en-us/library/24395wz3(v=vs.100).aspx
的摘录