log4net adonetappender变量为null

时间:2015-08-27 18:25:36

标签: variables stored-procedures logging log4net adonetappender

在谷歌搜索这个似乎永远的东西之后,我已经在这里提出了问题。

我在log4net adonetappender中添加了自定义字段和变量。然而,在重新处理它并尝试谷歌的前4页中找到的所有几乎所有建议之后,变量仍然是空的。

为什么会发生这种情况以及有任何建议可以提供帮助?

输出

RowId   Username    DateOfActivity  Thread  Level   Logger  Message Exception
16  (null)  2015-08-27 18:53:40.607 124732  DEBUG   LogToDatabaseTest.Form1 Retrieving info for ID

App.Config中

<parameter>
<parameterName value="@username"/>
<dbType value="String" />
<size value="100" />
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%property{username}"/>
    </layout>
  </parameter>
  <parameter>
    <parameterName value="@log_date"/>
    <dbType value="DateTime"/>
    <layout type="log4net.Layout.RawTimeStampLayout"/>
  </parameter>
  <parameter>
    <parameterName value="@thread"/>
    <dbType value="String"/>
    <size value="255"/>
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%thread"/>
    </layout>
  </parameter>
  <parameter>
    <parameterName value="@log_level"/>
    <dbType value="String"/>
    <size value="50"/>
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%level"/>
    </layout>
  </parameter>
  <parameter>
    <parameterName value="@logger"/>
    <dbType value="String"/>
    <size value="255"/>
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%logger"/>
    </layout>
  </parameter>
  <parameter>
    <parameterName value="@message"/>
    <dbType value="String"/>
    <size value="4000"/>
    <layout type="log4net.Layout.PatternLayout">
      <conversionPattern value="%message"/>
    </layout>
  </parameter>
  <parameter>
    <parameterName value="@exception"/>
    <dbType value="String"/>
    <size value="4000"/>
    <layout type="log4net.Layout.ExceptionLayout"/>
  </parameter>

设置变量的C#代码

private void simpleButton1_Click(object sender, EventArgs e)
{
ThreadContext.Properties["username"] = SystemInformation.UserName;

log4net.Config.XmlConfigurator.Configure();//(Watch = false)


try
{
    long_ID = Int64.Parse(textEdit1.Text);
}

catch (FormatException fe)
{
    XtraMessageBox.Show("ID inputted is not a number! Please enter a valid ID", "Error", MessageBoxButtons.OK, MessageBoxIcon.Hand);

    log.Error(String.Format("Retrieving Info for ID: {0}", textEdit1.Text), fe);

    return;
}
}

1 个答案:

答案 0 :(得分:0)

以上工作正常,我的编程逻辑出错了。当记录的事件被击中时,未设置变量。