从 Log4Net LogManager 获取 Appenders

Get Appenders from Log4Net LogManager

我试图通过 log4net 获取带有日志的文件名,但我无法获取我的 Appender。这是我的配置:

<log4net>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="name.log"/>
      <appendToFile value="false"/>
      <maximumFileSize value="10MB"/>
      <maxSizeRollBackups value="0"/>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date %level %thread %logger - %message%newline"/>
      </layout>
    </appender>
    <appender name="ColoredConsoleAppender" type="log4net.Appender.ColoredConsoleAppender">
      <mapping>
        <level value="ERROR"/>
        <foreColor value="Red, HighIntensity"/>
      </mapping>
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date %level %thread %logger - %message%newline"/>
      </layout>
    </appender>
    <root>
      <level value="DEBUG"/>
      <appender-ref ref="RollingFileAppender"/>
      <appender-ref ref="ColoredConsoleAppender"/>
    </root>
</log4net>

这是获取 appender 数量的代码:

((Hierarchy)LogManager.GetRepository()).GetAppenders().Length.ToString();

但它给了我 0。 日志记录工作完美,因此配置适用于日志记录。您是否知道如何在没有附加程序的情况下从配置中获取附加程序或文件名 "name.log"?谢谢。

您是否可能在调用 Configure 之前获取附加程序?

使用您提供的配置:

int count;
count = LogManager.GetRepository().GetAppenders().Length; // 0
XmlConfigurator.Configure();
count = LogManager.GetRepository().GetAppenders().Length; // 2