从第三方重定向log4net日志

本文关键字:日志 log4net 重定向 第三方 | 更新日期: 2023-09-27 17:50:16

我有一个第三方使用的配置文件,看起来像这样:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
    <!--Others sections-->
  </configSections>
  <log4net>
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value=".'logs'logclient.txt" />
      <appendToFile value="false" />
      <rollingStyle value="Date" />
      <maximumFileSize value="1000KB" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date  [%thread] %-5level %logger [%ndc] - %message%newline" />
      </layout>
    </appender>
    <root>
      <level value="DEBUG" />
      <appender-ref ref="RollingFileAppender" />
    </root>
  </log4net>
</configuration>

第三方代码如下:

LogManager.GetRepository(Assembly.GetCallingAssembly()), configFile);
LogManager.GetLogger(MethodBase.GetCurrentMethod().DeclaringType);

我希望第三方dll使用我自己在我自己的配置文件中定义的appender。我该怎么做呢?

注:

  • 第三方需要使用自己的配置文件,因为别人section是强制性的,我不能在我的文件
  • 中添加它们。
  • 我可以修改第三方的配置文件,我不能修改我自己的

从第三方重定向log4net日志

有两个问题提出了动态编辑log4net配置的解决方案:

  • 动态重新配置Log4Net
  • 如何以编程方式更改文件位置?(见JackAce回答)。

据我所知,你必须使用第三方配置文件,你可以修改它。

configSource属性/属性应该可以重定向第三方配置文件的log4net配置部分。

第三方配置文件:

<configSections>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
</configSections>
<log4net configSource="pathtoyourlog4net.config" />

log4net库是一个帮助程序员输出日志语句的工具到各种输出目标

你也可以在代码中配置log4net,而不是使用配置文件,这篇文章清楚地解释了这个问题。

动态修改appender:

public static void ChangeFilePath(string appenderName, string newFilename)
        {                       
            log4net.Repository.ILoggerRepository repository = log4net.LogManager.GetRepository();
            foreach (log4net.Appender.IAppender appender in repository.GetAppenders())
            {
                if (appender.Name.CompareTo(appenderName) == 0 && appender is log4net.Appender.FileAppender)
                {
                    log4net.Appender.FileAppender fileAppender = (log4net.Appender.FileAppender)appender;
                    fileAppender.File = System.IO.Path.Combine(fileAppender.File, newFilename);
                    fileAppender.ActivateOptions();                   
                }
            }           
        }

引用文章

如果你的。net应用程序引用了thirdparty.dll,在运行时应用程序将完全忽略thirdparty.dll.config。此外,thirdparty.dll不会拾取thirdparty.dll.config中的设置,因为它期望这些设置由exe加载。

你要做的是合并(或复制)thirdparty.dll.config的内容到你自己的app.config中。你的应用程序和第三方的。dll将能够获取你的app.exe.config中的设置,你只需要维护一个。config文件。

此外,你可以在log4net部分添加额外的appender,它将被你的应用程序和thirdparty.dll拾取。