7

asp.netWebアプリケーションに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)]

4。コードビハインドでのログ書き込み

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);       
}

これらは私が従った手順ですが、ログは作成されません...

提案をお願いします。

前もって感謝します

4

2 に答える 2

9

XmlConfiguratorのConfigure関数を呼び出していることを確認してください。

このソリューションを参照してください:WebアプリケーションでLog4Netを構成します

于 2012-11-23T11:33:05.950 に答える
5

asp.netユーザーまたはEveryoneのE:/ Logに書き込みアクセス許可を与えてから、次のようにrequirePermission="false"属性を追加してみてください。

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

または、次のように、ルートセクションでログレベルを指定する必要があります。

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

ここASP.NET3.5–ファイルアペンダーサンプルアプリケーション

于 2012-11-23T08:31:15.093 に答える