并非所有错误都被global.asax C#捕获

时间:2012-10-31 04:59:56

标签: c# error-handling global-asax elmah

我试图捕获所有错误,除了global.asax文件中的'404-File not found'错误并写入服务器中的文本文件,但很多错误都会被遗漏,比如FormatException错误,会话输出错误和“黄页错误”出现!

如何在此处捕捉所有错误。

void Application_Error(object sender, EventArgs e) 
{
    CT.Bussiness.DevCommonFunctions devTools = new CT.Bussiness.DevCommonFunctions();
    HttpContext ctx = HttpContext.Current;
    //ctx.Response.
    // Get page url
    if (ctx != null)
    {
        string pageName = ctx.Request.Url.ToString();

        Exception ex = Server.GetLastError().GetBaseException();
        HttpException checkException = (HttpException)ex;
        if (checkException.GetHttpCode() != 404)
        {
            string errorDate = DateTime.Now.ToString();
            //string pageName =pageName;
            string errorMessage = ex.Message;
            string errorSource = ex.Source;
            //string errorInnerException=ex.InnerException.ToString();
            string errorData = ex.Data.ToString();
            string errorTarget = ex.TargetSite.ToString();
            string errorStack = ex.StackTrace.ToString();
            devTools.WriteErrorsIntoErrorLog(errorDate, pageName, errorMessage, errorSource, "InnerException", errorData, errorTarget, errorStack);
            //devTools.SendErrorMail("developer3@devwebservices.net,developer4@devwebservices.net,developer5@devwebservices.net,hr@devwebservices.net", errorDate, pageName, errorMessage, errorSource, "InnerException", errorData, errorTarget, errorStack);
            //Response.TrySkipIisCustomErrors = true;
            Response.Redirect("~/Error.aspx");
            //Response.Redirect("Error.aspx");

        }
    }
}

解决

我跟随KPL建议如下:

  1. 实施Elmah
  2. 排除Global.asax和
  3. 在web.config中编写了重定向代码。
  4. 因此解决了!

1 个答案:

答案 0 :(得分:0)

使用:

1。)web.config" customErrors"标记以避免"黄页错误":

<customErrors mode="On" defaultRedirect="~/Error.aspx">
      <error statusCode="400" redirect="/error/400-bad-request/" />
      <error statusCode="404" redirect="/error/404-file-not-found/" />
      <error statusCode="500" redirect="/error/500-server-error/" />
</customErrors>

2。)另请尝试使用Elmah来记录错误。

ELMAH(错误记录模块和处理程序)是一个完全可插拔的应用程序范围的错误记录工具。它可以动态添加到正在运行的ASP.NET Web应用程序,甚至是机器上的所有ASP.NET Web应用程序,而无需重新编译或重新部署。

将ELMAH放入正在运行的Web应用程序并进行适当配置后,您将获得以下功能,而无需更改单行代码:

  • 记录几乎所有未处理的例外情况。
  • 远程查看已重新编码的例外日志的网页。
  • 用于远程查看任何一个已记录异常的完整详细信息的网页,包括彩色堆栈跟踪。
  • 在许多情况下,即使关闭了customErrors模式,您也可以查看ASP.NET为特定异常生成的原始黄色死亡屏幕。
  • 发生时每个错误的电子邮件通知。
  • 日志中最近15个错误的RSS提要。