gpt4 book ai didi

c# - 您可以在代码中配置 log4net 而不是使用配置文件吗?

转载 作者:IT王子 更新时间:2023-10-29 03:33:35 26 4
gpt4 key购买 nike

我理解为什么 log4net 使用 app.config 文件来设置日志记录 - 这样您就可以轻松更改信息的记录方式,而无需重新编译您的代码。但就我而言,我不想将 app.config 文件与我的可执行文件一起打包。而且我不想修改我的日志记录设置。

有没有办法让我设置登录代码而不是使用 app.config

这是我的简单配置文件:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
</configSections>
<log4net>
<appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="Logs\EventLog.txt" />
<appendToFile value="false" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="5" />
<maximumFileSize value="1GB" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger - %message%newline" />
</layout>
</appender>
<appender name="MemoryAppender" type="log4net.Appender.MemoryAppender">
</appender>
<root>
<level value="Info" />
<appender-ref ref="RollingLogFileAppender" />
<appender-ref ref="MemoryAppender" />
</root>
</log4net>
</configuration>

编辑:

完全清楚:我的目标是没有 XML 文件。甚至不作为我变成流的嵌入式资源。我的目标是以编程方式完全定义记录器。只是好奇这是否可能,如果可能的话,我可以在哪里找到语法示例。

最佳答案

最终解决方案:1

对于将来可能偶然发现此问题的任何人,这就是我所做的。我制作了下面的静态类:

using log4net;
using log4net.Repository.Hierarchy;
using log4net.Core;
using log4net.Appender;
using log4net.Layout;

namespace Spectrum.Logging
{
public class Logger
{
public static void Setup()
{
Hierarchy hierarchy = (Hierarchy)LogManager.GetRepository();

PatternLayout patternLayout = new PatternLayout();
patternLayout.ConversionPattern = "%date [%thread] %-5level %logger - %message%newline";
patternLayout.ActivateOptions();

RollingFileAppender roller = new RollingFileAppender();
roller.AppendToFile = false;
roller.File = @"Logs\EventLog.txt";
roller.Layout = patternLayout;
roller.MaxSizeRollBackups = 5;
roller.MaximumFileSize = "1GB";
roller.RollingStyle = RollingFileAppender.RollingMode.Size;
roller.StaticLogFileName = true;
roller.ActivateOptions();
hierarchy.Root.AddAppender(roller);

MemoryAppender memory = new MemoryAppender();
memory.ActivateOptions();
hierarchy.Root.AddAppender(memory);

hierarchy.Root.Level = Level.Info;
hierarchy.Configured = true;
}
}
}

然后我所要做的就是用以下调用替换调用 XML 文件的代码:

//XmlConfigurator.Configure(new FileInfo("app.config")); // Not needed anymore
Logger.Setup();

1(这个答案被OP编辑到问题中,我冒昧地把它作为一个社区答案,see here why)

关于c# - 您可以在代码中配置 log4net 而不是使用配置文件吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16336917/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com