包含堆栈跟踪/错误输出的完整跟踪c#

时间:2014-06-12 09:56:15

标签: c# asp.net webforms

我在global.asax文件中使用以下代码:

void Application_Error(object sender, EventArgs e)
{
    // Code that runs when an unhandled error occurs
    Exception objErr = Server.GetLastError().GetBaseException();
    string err = "Error Caught in Application_Error event<hr />" + "Current User: " + HttpContext.Current.User.Identity.Name + "<hr />" +
            "Error in: " + Request.Url.ToString() +
            "<hr />Error Message:" + objErr.Message.ToString() +
            "<hr />Stack Trace:" + objErr.StackTrace.ToString();
    //EventLog.WriteEntry("Sample_WebApp", err, EventLogEntryType.Error);

    doEmail.sendEmail("Application Error - Curato (" + System.Configuration.ConfigurationManager.AppSettings["OrganisationName"].ToString() + ")", err);

    // We do not want the error handled by the web.config as well, so clear the error.
    Server.ClearError();
    // Now redirect ourselves...
    Response.Redirect("~/error.aspx?aspxerrorpath=" + Server.UrlEncode(Request.Url.PathAndQuery));
}

这会将stackTrace和当前用户发送到管理员电子邮件地址,并将用户重定向到友好的错误页面。

如何在err中包含完整的跟踪信息?也就是说,就像我在Trace="True"指令中设置了<%@ Page一样的信息。

我正在探索Trace对象 - 并找到了如何从第三方阅读器how to read trace阅读它,但我想用本机代码阅读它。

1 个答案:

答案 0 :(得分:0)

您已经获得异常的完整StackTrace,我相信您正在查看错误的Exception对象:

我认为您的错误就在这一行:

Exception objErr = Server.GetLastError().GetBaseException();

我认为正确的应该是:

Exception objErr = Server.GetLastError();

您还可以检查异常以查看是否存在InnerException:

if (objErr.InnerException != null)
    err = err + "<hr/>Message:" +  objErr.InnerException.Message;

还可以看到这个问题: Application_Error - GetLastError() or GetLastError().GetBaseException()