War*_*War 5 c# wpf log4net log4net-configuration
我不敢相信我不得不问这个,但这里是......
我正在尝试在新的 WPF 应用程序中设置 log4net,但出于某种原因,它没有创建日志文件并记录任何内容,所以这是我到目前为止所做的步骤......
从 nuget 添加最新版本 (v2.0.8.0) 参考后。
在 AssemblyInfo.cs 中:
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4Net.config", Watch = true)]
Run Code Online (Sandbox Code Playgroud)
在 app.config 中:
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net, Version=2.0.8.0, Culture=neutral, PublicKeyToken=669e0ddf0bb1aa2a" />
</configSections>
<log4net configSource="Log4Net.config" />
Run Code Online (Sandbox Code Playgroud)
在 Log4Net.config 中:
<?xml version="1.0" encoding="utf-8"?>
<log4net>
<appender name="rollingLogFile" type="log4net.Appender.RollingFileAppender">
<file value="D:\Logs\WorkflowApp.log" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="100KB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-6level %logger - %message %exception%newline" />
</layout>
</appender>
<root>
<level value="DEBUG" />
<appender-ref ref="rollingLogFile" />
</root>
</log4net>
Run Code Online (Sandbox Code Playgroud)
在 App.xaml.cs 中:
ILog log = LogManager.GetLogger(typeof(App));
protected override void OnStartup(StartupEventArgs e)
{
base.OnStartup(e);
log.Debug("Initialising ...");
}
Run Code Online (Sandbox Code Playgroud)
作为最后一个“尝试看看它是否有效”,我将其添加到上述方法中......
XmlConfigurator.Configure();
Run Code Online (Sandbox Code Playgroud)
...仍然没有创建长文件。
那么我错过了什么?
编辑:
所以根据评论,我想我应该添加这个:
我见过这样的问题和答案...... 使用 log4net 写入不同的记录器
...如果我将这样的内容添加到我的 Log4Net.config ...
<logger name="File">
<level value="DEBUG" />
<appender-ref ref="rollingLogFile" />
</logger>
Run Code Online (Sandbox Code Playgroud)
然后将我的记录器构造更改为...
ILog log = LogManager.GetLogger("File");
Run Code Online (Sandbox Code Playgroud)
...然而,这仍然没有发生任何事情,没有日志文件但没有异常,除了似乎执行但没有结果的日志记录调用之外,代码似乎运行良好。
| 归档时间: |
|
| 查看次数: |
5505 次 |
| 最近记录: |