我在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阅读它,但我想用本机代码阅读它。
答案 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()