我是 Log4net 的新手。我已经设法通过添加配置文件和简单的日志记录来取得进展。我已将该值硬编码为 "C:\temp\log.txt"
但这还不够好。
日志必须放在特殊文件夹中
path = Environment.GetFolderPath(Environment.SpecialFolder.CommonApplicationData);
并且此路径会根据您使用的是 Windows Server 2008 还是 Windows XP 或 Vista 等而变化...
我怎样才能以编程方式更改文件在 log4net 中的位置?
这是我所做的:
<configSections>
<section name="log4net"
type="log4net.Config.Log4NetConfigurationSectionHandler,Log4net"/>
</configSections>
<log4net>
<root>
<level value="DEBUG" />
<appender-ref ref="LogFileAppender" />
</root>
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="C:\temp\log.txt" />
<param name="AppendToFile" value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="10MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%-5p%d{yyyy-MM-dd hh:mm:ss} – %m%n" />
</layout>
</appender>
</log4net>
class Program
{
protected static readonly ILog log = LogManager.GetLogger(typeof(Program));
static void Main(string[] args)
{
log4net.Config.XmlConfigurator.Configure();
log.Warn("Log something");
path = Environment.GetFolderPath(Environment.SpecialFolder.CommonApplicationData);
// How can I change where I log stuff?
}
}
只需要弄清楚如何更改以将内容记录到我想要的位置。
有什么建议吗? 非常感谢
最佳答案
log4net 可以为您处理。可以格式化任何字符串类型的附加程序属性,在这种情况下,使用 log4net.Util.PatternString选项处理程序。 PatternString 甚至支持 SpecialFolder启用以下优雅配置的枚举:
<appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender" >
<file type="log4net.Util.PatternString"
value="%envFolderPath{CommonApplicationData}\\test.txt" />
...
</appender>
这是一个证明布丁的单元测试:
[Test]
public void Load()
{
XmlConfigurator.Configure();
var fileAppender = LogManager.GetRepository()
.GetAppenders().First(appender => appender is RollingFileAppender);
var expectedFile =
Path.Combine(
Environment.GetFolderPath(
Environment.SpecialFolder.CommonApplicationData),
"test.txt");
Assert.That(fileAppender,
Is.Not.Null & Has.Property("File").EqualTo(expectedFile));
}
以下测试验证 log4net 是否确实写入磁盘(这基本上使它成为“集成”测试,而不是单元测试,但我们现在将其保留):
[Test]
public void Log4net_WritesToDisk()
{
var expectedFile =
Path.Combine(
Environment.GetFolderPath(
Environment.SpecialFolder.CommonApplicationData),
"test.txt");
if (File.Exists(expectedFile))
File.Delete(expectedFile);
XmlConfigurator.Configure();
var log = LogManager.GetLogger(typeof (ConfigTest));
log.Info("Message from test");
LogManager.Shutdown();
Assert.That(File.ReadAllText(expectedFile),
Text.Contains("Message from test"));
}
注意:我强烈建议使用上面示例中演示的紧凑属性语法。删除所有这些“
关于c# - 如何以编程方式更改文件位置?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1535736/