log4net 正在捕获除堆栈跟踪之外的所有内容

log4net is capturing everything except the stack trace

我是 Log4Net 的新手。我已经能够实现我在​​网上找到的以下代码。它在捕获和保存数据方面工作正常,即日期、登录的用户、IP 地址...

唯一的问题是异常字段空白。我想捕获 堆栈跟踪

public void Application_Error(object sender, EventArgs e)
    {
        //Fires when an error occurs
        var redirectUrl = "~/Error/GenericError.aspx";
        var httpException = (HttpException)Server.GetLastError();
        int httpCode = httpException.GetHttpCode();

        log4net.GlobalContext.Properties("ipaddress") 
                                    = Request.ServerVariables("remote_addr");
        log4net.GlobalContext.Properties("thread") = Request.Url.AbsoluteUri;
        log4net.GlobalContext.Properties("userid") = User.Identity.Name;

        var ctx = HttpContext.Current;
        var _url = ctx.Request.Url.ToString();
        log4net.GlobalContext.Properties("url") = _url;
        log4net.GlobalContext.Properties("browser") = ctx.Request.Browser.Browser;

        log4net.ILog log = log4net.LogManager.GetLogger(this.GetType());
        log.Error(httpException.Message);


        if ((httpCode == 404))
        {
            redirectUrl = "~/Error/FileNotFound.aspx";
        }
        else if ((httpCode == 403))
        {
            redirectUrl = "~/Error/UnauthorizedAccess.aspx";
        }
        else
        {
            var message = string.Empty;
            if (httpException is HttpRequestValidationException)
            {
                message = "A potentially dangerous Request.Form value"
                                    + " was detected from the client.";
            }
            else
            {
                message = httpException.Message;
            }
            redirectUrl = "~/Error/GenericError.aspx?msg=" + message;
        }

        Server.ClearError();
        Server.Transfer(redirectUrl);
    }

这是 webconfig 的 log4net 部分

 <parameter>
    <parameterName value="@exception" />
    <dbType value="String" />
    <size value="2000" />
    <layout type="log4net.Layout.ExceptionLayout" />
  </parameter>

感谢您的帮助

您需要使用 overload of Error that lets you pass the exception along with the message:

Log a message object with the Error level including the stack trace of the Exception passed as a parameter.

因此您的代码将是:

log.Error("Error in global handler", httpException); // or other message