GlobalContext.Properties 不起作用,尽管随后调用了 XMLConfigurator.Configure
GlobalContext.Properties doesn't work although XMLConfigurator.Configure is called afterwards
我在我的 log4net appender 中设置了一个全局 属性,我想在其中获取 exe 的当前路径作为日志文件的路径。
这是我的 App.config:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="%property{LogFileName}.log"/>
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="2" />
<maximumFileSize value="10MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p %c %m%n"/>
</layout>
</appender>
<root>
<level value="ALL" />
<appender-ref ref="LogFileAppender" />
</root>
</log4net>
</configuration>
所以在这里我将 属性 设置为 %property{LogFileName}.log
这是我在脚本中设置 属性 的片段:
var directory = Path.GetDirectoryName(Process.GetCurrentProcess().MainModule.FileName);
GlobalContext.Properties["LogFileName"] = directory + "/AccesDBReader"; //log file path
log4net.Config.XmlConfigurator.Configure();
我在设置了属性之后设置了XMLConfigurator.Configure()
,所以我不明白哪里出了问题。
指定 file
设置值的方式应如下所示。
请注意使用的是 file
标签而不是 param
并包含 type="log4net.Util.PatternString"
说明符。
<file type="log4net.Util.PatternString" value="%property{LogFileName}.log" />
我在我的 log4net appender 中设置了一个全局 属性,我想在其中获取 exe 的当前路径作为日志文件的路径。
这是我的 App.config:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="%property{LogFileName}.log"/>
<lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="2" />
<maximumFileSize value="10MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%t] %-5p %c %m%n"/>
</layout>
</appender>
<root>
<level value="ALL" />
<appender-ref ref="LogFileAppender" />
</root>
</log4net>
</configuration>
所以在这里我将 属性 设置为 %property{LogFileName}.log
这是我在脚本中设置 属性 的片段:
var directory = Path.GetDirectoryName(Process.GetCurrentProcess().MainModule.FileName);
GlobalContext.Properties["LogFileName"] = directory + "/AccesDBReader"; //log file path
log4net.Config.XmlConfigurator.Configure();
我在设置了属性之后设置了XMLConfigurator.Configure()
,所以我不明白哪里出了问题。
指定 file
设置值的方式应如下所示。
请注意使用的是 file
标签而不是 param
并包含 type="log4net.Util.PatternString"
说明符。
<file type="log4net.Util.PatternString" value="%property{LogFileName}.log" />