我有第三方使用如下所示的配置文件:
<?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。我该如何管理这个?
注意:
答案 0 :(得分:2)
现有两个问题提出了动态编辑log4net配置的解决方案:
答案 1 :(得分:2)
据我了解,您必须使用第三方配置文件,您可以对其进行修改。
configSource属性/属性应该可以重定向第三方配置文件的log4net配置部分。
在第三方配置文件中:
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
</configSections>
<log4net configSource="pathtoyourlog4net.config" />
答案 2 :(得分:0)
如果您的.NET应用程序引用了thirdparty.dll,则在运行时应用程序将完全忽略thirdparty.dll.config。此外,thirdparty.dll将不会拾取thirdparty.dll.config中的设置,因为它期望这些设置由exe加载。
您需要做的是将thirdparty.dll.config的内容合并(或复制)到您自己的app.config中。您的应用和thirdparty.dll都可以在app.exe.config中获取设置,您只需要维护一个.config文件。
此外,您可以在log4net部分添加其他appender,它将被您的应用和thirdparty.dll一起提取。
答案 3 :(得分:0)
log4net库是一个帮助程序员输出日志语句的工具 达到各种输出目标。
您还可以在代码中配置log4net
而不是使用配置文件,this SO帖子清楚地解释了这个问题。
动态更改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();
}
}
}