首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >GlobalContext.Properties不起作用,尽管后来调用了XMLConfigurator.Configure

GlobalContext.Properties不起作用,尽管后来调用了XMLConfigurator.Configure
EN

Stack Overflow用户
提问于 2021-01-18 10:11:20
回答 1查看 89关注 0票数 0

我在我的log4net附录中设置了一个全局属性,在这里,我希望获取exe的当前路径作为日志文件的路径。

这是我的App.config:

代码语言:javascript
复制
<?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

这是代码段,我在脚本中设置了这个属性:

代码语言:javascript
复制
        var directory = Path.GetDirectoryName(Process.GetCurrentProcess().MainModule.FileName);

        GlobalContext.Properties["LogFileName"] = directory + "/AccesDBReader"; //log file path
        log4net.Config.XmlConfigurator.Configure();

我在设置属性之后设置了XMLConfigurator.Configure(),所以我不知道出了什么问题。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-01-20 19:03:41

指定file设置值的方法如下所示。

注意使用的是file标记而不是param

以及type="log4net.Util.PatternString"说明符的加入。

代码语言:javascript
复制
<file type="log4net.Util.PatternString" value="%property{LogFileName}.log" />
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65772468

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档