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
我是 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