私はWPFアプリケーションでlog4netを使用しています。 log4netはVisual Studioからアプリケーションを実行しているときに動作しますが、実行可能ファイル経由でアプリケーションを実行すると動作しません。bin
。WPFアプリケーションの実行可能ファイルを実行しているときにlog4netが動作しない
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<log4net debug="true">
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="C:/ProgramData/CompApps/Logs/AppName/log.txt" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="25" />
<maximumFileSize value="20MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%utcdate UTC %property{log4net:HostName} [%thread] %-5level %logger - %method() - %message%newline" />
</layout>
</appender>
<root>
<level value="Info" />
<appender-ref ref="RollingFileAppender" />
</root>
</log4net>
</configuration>
log4net.config
性質
Build Action: Content
Copy to Output Directory: Copy always
AssemblyInfo.cs
:
// log4net config
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "log4net.config", Watch = true)]
そして、これは各クラスで使用されている私たちはここで、log4net.config
ファイルを使用している
は、それは次のようになります。ロガーを使用したい:
private static readonly ILog log = LogManager.GetLogger(typeof(App));
アプリケーションを実行している**ユーザ**には、 'C:/ ProgramData/CompApps/Logs/AppName /'に対する書き込み権がありますか? – ChrisF
はい、アプリケーションを実行しているユーザは 'C:/ ProgramData/CompApps/Logs/AppName /'への書き込み権を持っています – Cole
'debug =" true "' .exeから実行するとログに記録されません。 –