我在我的AsP.NET站点上运行了log4net。我可以将消息记录到我的DB表中,但它没有记录ThreadContext属性。例如:
ThreadContext.Properties["Url"] = HttpContext.Current.Request.Url.ToString();
ThreadContext.Properties["HttpReferer"] = HttpContext.Current.Request.ServerVariables["HTTP_REFERER"];我的log4net.config将这些值作为参数添加到我的SQL DB表中:
<parameter>
<parameterName value="@URL"/>
<dbType value="String"/>
<size value="512"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{log4net:Url}"/>
</layout>
</parameter>
<parameter>
<parameterName value="@HttpReferer"/>
<dbType value="String"/>
<size value="512"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%property{log4net:HttpReferer}"/>
</layout>
</parameter>当我调试时,我看到那些ThreadContext属性正在被设置,但是它们没有进入数据库。
我怎么才能让它工作呢?
发布于 2008-10-09 19:08:31
所以,事实证明是配置造成的。这是一个小错误:
原件:
<conversionPattern value="%property{log4net:HttpReferer}"/>已更改:
<conversionPattern value="%property{HttpReferer}"/>我不得不去掉属性中的"log4net:“。
奇怪的是,还有一个属性仍然需要log4net:propertyName。我完全不知道为什么它是这样工作的,但这就是有效的修复!
发布于 2008-10-09 14:09:41
您可以打开/debug/show log4net来查看它在该级别上所做的工作吗?有没有可能需要另外一点配置来把这一切联系在一起?
https://stackoverflow.com/questions/187284
复制相似问题