log4net log4net.Util.PatternString从代码配置

ngi*_*ngi 5 .net c# log4net console-application

我有一个带有log4net的控制台应用程序,我想从代码中添加日志文件名.(我稍后使用线程)

class Program
{
    static void Main(string[] args)
    {
        {
            log4net.GlobalContext.Properties["fname"] = "aaaa";
            log4net.Config.XmlConfigurator.Configure();
        }
    }
}

<appender name="default" type="log4net.Appender.RollingFileAppender">
   <file type="log4net.Util.PatternString" value="d:\\TEMP\\default_%property{fname}.log"/>
...
</appender>
Run Code Online (Sandbox Code Playgroud)

我得到(null).

谢谢你的帮助.

小智 0

它对我有用 - 我使用了 log4net 1.2.11 以下是我正在使用的示例配置(我使用了与您相同的 C# 代码):

<?xml version="1.0"?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
  </configSections>

  <log4net>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file type="log4net.Util.PatternString" value="default_%property{fname}.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] %-5level %logger [%property{NDC}] - %message%newline"/>
      </layout>
    </appender>

    <root>
      <priority value="ALL"/>
      <appender-ref ref="RollingFileAppender"/>
    </root>

  </log4net>
</configuration>
Run Code Online (Sandbox Code Playgroud)