WPF log4net未写入日志文件

时间:2018-03-19 08:53:52

标签: wpf log4net

我有一个WPF解决方案。我下载了log4net dll,我添加了log4net.config,并将“复制到输出目录”的值设置为“始终复制”。

log4net.config:

 <?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <log4net>
    <root>
      <level value="ALL" />
      <appender-ref ref="LogFileAppender" />
    </root>
    <appender name="LogFileAppender" type="log4net.Appender.FileAppender">
      <file value="myapp.txt" />
      <appendToFile value="true" />
      <rollingStyle value="Size" />
      <maxSizeRollBackups value="5" />
      <maximumFileSize value="10MB" />
      <staticLogFileName value="true" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date [%thread] %level %logger - %message%newline" />
      </layout>
    </appender>
  </log4net>
</configuration>

我在 AssemblyInfo.cs:

中添加了以下行
  [assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]

然后我的 TestWindowControl.xaml.cs

中的以下代码
public partial class TestWindowControl : UserControl
        {
            private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

            public TestWindowControl()
            {
                XmlConfigurator.Configure(new System.IO.FileInfo("log4net.config"));
                log.Info("info testing");
                log.Debug("debug testing");
                log.Error("error testing");
                log.Fatal("fatal testing");
                log.Warn("warn testing");
            }
        }

但是日志没有写入文件。它在控制台应用程序中工作,但不适用于WPF。我错过了什么吗?

1 个答案:

答案 0 :(得分:0)

尝试在appender中设置过滤器

<filter type="log4net.Filter.LevelRangeFilter">
  <levelMin value="WARN" />
  <levelMax value="ERROR" />
</filter>