7

我们正在使用 asp.net 配置设置提供的自定义错误。在整个应用程序(PL/BLL/DAL)中,我们没有使用任何 try catch。因此,对于任何层应用程序中的任何异常,将用户重定向到配置文件中自定义错误设置中设置的自定义错误页面。现在我们要在显示错误页面之前在日志文件中记录以下信息:

- Date & time
- Exception message & strack trace.
- Page Name
- Method Name
- Method Parameter & values.

请帮助我如何在自定义错误 page_load 事件中收集上述信息?

谢谢,

@保罗

4

2 回答 2

12

您可以在会话中存储错误详细信息并在自定义错误页面中获取它们。

此代码位于Global.asax中:

    protected void Application_Error(object sender, EventArgs e)
    {
        Exception err = Server.GetLastError();
        Session.Add("LastError", err);
    }

    void Session_Start(object sender, EventArgs e) 
    {      
        Session["LastError"] = ""; //initialize the session
    }

然后在你的错误页面加载:

    protected void Page_Load(object sender, EventArgs e)
    {
        Exception err = Session["LastError"] as Exception;
        //Exception err = Server.GetLastError();
        if (err != null)
        {
            err = err.GetBaseException();
            lblErrorMsg.Text = err.Message;
            lblSource.Text = err.Source;
            lblInnerEx.Text = (err.InnerException != null) ? err.InnerException.ToString() : "";
            lblStackTrace.Text = err.StackTrace;
            Session["LastError"] = null;
        }
    }
于 2012-08-05T07:57:38.600 回答
0

在 web.config 的 customErrors 部分设置此属性:redirectMode="ResponseRewrite"

于 2016-02-12T14:33:06.243 回答