log4Net日志文件未写入

7

我正在尝试在我的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);       
}

以下是我遵循的步骤,但是日志并没有被创建...请给出您的建议。谢谢!

1
你确定你对 E:/Log/error_%date{dd-MM-yyyy}.log 有写入权限吗? - Christian Westman
我有在E盘写入的权限。 - Shibin V.M
你是如何托管你的应用程序的,使用IIS吗? - Tommy Grovnes
应用程序没有托管在IIS上,而是在VS中运行。 - Shibin V.M
你的 web.config 文件的第二行应该在 name="log4net" 和 type="..." 之间加上一个空格。 - sgmoore
2个回答

9

5
尝试给asp.net用户或每个人在E:/Log中设置写入权限, 然后尝试添加requirePermission="false"属性,如下所示:
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,Log4net" requirePermission="false" />

或者您可以在根部分指定日志记录级别,像这样:
<root>
  <level value="ALL" />
  <appender-ref ref="RollingFileAppender" />
</root>

这里是一个ASP.NET 3.5文件记录器的示例应用程序


1
权限让我有些困惑。很好的发现。 - erlingormar

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接