我应该如何配置log4net以在Windows XP和7上写入%LOCALAPPDATA%? [英] How should I configure log4net to write to %LOCALAPPDATA% on Windows XP and 7?
问题描述
我有一个内部应用程序,该应用程序使用log4net进行日志记录.我希望在%LOCALAPPDATA%\Vendor\App\application.log
处生成日志.不幸的是,log4net在%APPDATA%
处创建了日志文件.这不是一个大问题,因为我们确实不使用这里描述的漫游,但是如果可以避免的话,我不希望在代码中留下一点特质.
I've got an internal app which is using log4net for logging. I'd like the logs to be generated at %LOCALAPPDATA%\Vendor\App\application.log
. Unfortunately, log4net is creating the log file at %APPDATA%
instead. It's not a huge problem, because we really don't use roaming profiled here, but I don't like leaving little idiosyncrasies in my code if I can avoid it.
是否有任何想法如何将文件写入我指定的位置,而无需以编程方式配置log4net并使用pinvoke来获取XP的路径?
Any thoughts on how to get the file written to the location I specified without configuring log4net programattically and using pinvoke to get the path for XP?
这是我的配置文件的附加程序部分,如果有帮助的话:
Here's the appender section of my config file if it's any help:
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="${LOCALAPPDATA}\Vendor\App\application.log" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="100KB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %-5level %logger%newline%message%newline" />
</layout>
</appender>
推荐答案
如果这不起作用,则表明您的环境变量不正确.
If this isn't working, it would imply your environment variable is wrong.
Log4net中没有任何特殊内容来处理appdata或localappdata.它所做的只是调用System.Environment.GetEnvironmentVariables()
以返回哈希表,并根据返回的值进行替换.
Log4net does not have anything special in it to handle either appdata or localappdata. All it does is call System.Environment.GetEnvironmentVariables()
to return a hashtable and performs substitution based on whatever values that returns.
这篇关于我应该如何配置log4net以在Windows XP和7上写入%LOCALAPPDATA%?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!