log4Net日志文件没有写入

时间:2012-11-23 08:19:35

标签: c# asp.net logging log4net

我正在尝试在我的asp.net Web应用程序中实现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);       
}

这些是我遵循的步骤,但未创建日志......

请提出您的建议。

提前致谢

2 个答案:

答案 0 :(得分:9)

确保您正在调用 XmlConfigurator 配置功能。

请参阅此解决方案:Configure Log4Net in web application

答案 1 :(得分:5)

尝试在E:/ Log中为asp.net用户或Everyone提供写入权限, 然后尝试添加requirePermission =“false”属性,如下所示:

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

或者你应该在root部分指定日志级别,如下所示:

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

here ASP.NET 3.5 – File Appender sample application