2012-11-23 39 views
7

私はasp.net Webアプリケーションでlog4netを実装しようとしています。しかし残念ながら、ファイルは作成されません。以下は私の設定です。log4Netログファイルが書き込まれない

1。 log4net .dllリファレンスの追加

2。 Web.configの設定。

<configSections> 
    <section name="log4net"type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/> 
    </configSections> 
    <log4net> 
    <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender"> 
     <file type="log4net.Util.PatternString" value="E:/Log/error_%date{dd-MM-yyyy}.log"/> 
     <appendToFile value="true"/> 
     <rollingStyle value="Date"/> 
     <!--<maxSizeRollBackups value="5"/> 
     <maximumFileSize value="10MB"/> 
     <staticLogFileName value="true"/>--> 
     <datePattern value="yyyyMMdd" /> 
     <layout type="log4net.Layout.PatternLayout"> 
     <conversionPattern value="%date [%thread] %level %logger - %message%newline%exception%newline%newline"/> 
     </layout> 
    </appender> 
    <root> 
     <appender-ref ref="RollingFileAppender"/> 
    </root> 

    </log4net> 

3。アセンブリの参照を追加しました

 [assembly: log4net.Config.XmlConfigurator(Watch = true)] 
private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType); 

try 
{ 
    throw new System.IO.FileNotFoundException(); 
} 
catch (Exception ex) 
{  
    log.Error("Error error logging", ex);  
} 

これらは私が続いていた段階ですが、ログが作成されていないの背後にあるコードで書くログイン...

はあなたの提案をお願いします。事前に

おかげEに書き込み権限を与えるために

+1

は、あなたがEへの書き込み権限を持っていることを確認している:/ログ/ ERROR_%の日{DD-MM-yyyyは} .logの? –

+0

ys ..私はEドライブに書き込みを許可しています –

+0

どのようにあなたのアプリケーション、IISをホストしていますか? –

答えて

5

試してみてください/ログのasp.netユーザーのためやみんなのために、 は、このように、requirePermission = "false" 属性を追加しよう:

<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,Log4net" requirePermission="false" /> 

か、このように、根元部にログレベルを指定する必要があります。

<root> 
    <level value="ALL" /> 
    <appender-ref ref="RollingFileAppender" /> 
</root> 

here ASP.NET 3.5 – File Appender sample application

+1

許可が私を襲った。良いキャッチ。 – erlingormar

関連する問題