Asp.net web api 还有一个:log4net日志文件是';t创造

Asp.net web api 还有一个:log4net日志文件是';t创造,asp.net-web-api,log4net,Asp.net Web Api,Log4net,关于配置log4net有很多问题/答案,我已经看了一段时间了。是时候问我自己的问题了。 我的问题是我的“WebAPI”Web服务不创建日志文件。我 要在以下位置创建日志文件:C:\Logs。我已仔细检查是否有写入此文件夹的权限。此外,我们使用 log4net用于我们的功能测试,当我运行测试时,会创建FunctionalTests.log文件。因此,我认为我们可以 排除权限 我做错了什么 我的AssemblyInfo.cs文件中有以下行: [assembly: log4net.Config.Xml

关于配置log4net有很多问题/答案,我已经看了一段时间了。是时候问我自己的问题了。 我的问题是我的“WebAPI”Web服务不创建日志文件。我 要在以下位置创建日志文件:C:\Logs。我已仔细检查是否有写入此文件夹的权限。此外,我们使用 log4net用于我们的功能测试,当我运行测试时,会创建FunctionalTests.log文件。因此,我认为我们可以 排除权限

我做错了什么

我的AssemblyInfo.cs文件中有以下行:

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4Net.config", Watch = true)]
当应用程序启动时,我调用XmlConfigurator.Configure()。在我的调试器中,我可以看到应用程序启动被命中 并调用Configure()方法:

public class WebApiApplication : HttpApplication
{
    protected void Application_Start()
    {
        XmlConfigurator.Configure();
        HibernateConfig.InitHibernate();
    }
这是我的Log4Net.config文件,位于我的项目的根级别:

<log4net debug="true">
  <!-- Level 1 -->
  <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender">
    <param name="File" value="C:\Logs\WebAPI.log"/>
    <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
    <appendToFile value="true" />
    <rollingStyle value="Size" />
    <maxSizeRollBackups value="2" />
    <maximumFileSize value="1000MB" />
    <staticLogFileName value="true" />
    <layout type="log4net.Layout.PatternLayout">
     <param name="ConversionPattern" value="%d %property{X-CLIENT-REQUEST-ID} %property{X-REQUEST-ID} [%t] %-5p %c %m%n"/>
    </layout>
  </appender>

  <appender name="RequestLogAppender" type="log4net.Appender.RollingFileAppender">
    <param name="File" value="C:\Logs\WebAPIRequests.log"/>
    <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
    <appendToFile value="true" />
    <rollingStyle value="Size" />
    <maxSizeRollBackups value="2" />
    <maximumFileSize value="1000MB" />
    <staticLogFileName value="true" />
    <layout type="log4net.Layout.PatternLayout">
      <param name="ConversionPattern" value="%d %property{X-CLIENT-REQUEST-ID} %property{X-REQUEST-ID} [%t] %-5p %c %m%n"/>
    </layout>
  </appender>

  <root>
    <level value="ALL" />
    <appender-ref ref="LogFileAppender" />
  </root>
  <logger additivity="false" name="Request">
    <level value="INFO" />
    <appender-ref ref="RequestLogAppender" />
  </logger>
</log4net>

问题在于visual studio没有将我的log4net.config文件复制到bin目录。修复方法:右键单击log4net.config->properties->copy always

我还有第二个问题要解决。即使在bin目录下,也没有读取我的配置文件。我编辑了Web.config文件并添加了以下两行:

<appSettings>
    <add key="log4net.Config" value="Log4Net.config"/>
    <add key="log4net.Config.Watch" value="True"/>
</appSettings>

迟做总比不做好=]

在web.config上遵循我的配置

    <log4net debug="false">
      <appender name="LogFileAppender" type="log4net.Appender.RollingFileAppender,log4net">
        <param name="File" value="log/log" />
        <param name="AppendToFile" value="true" />
        <param name="rollingStyle" value="Composite" />
        <param name="datePattern" value="yyyyMMdd" />
        <param name="MaximumFileSize" value="100MB" />
        <param name="MaxSizeRollBackups" value="-1" />
        <param name="StaticLogFileName" value="false" />
        <layout type="log4net.Layout.PatternLayout,log4net">
           <param name="ConversionPattern" value="%d [%t] %-5p - %m%n" />
        </layout>
      </appender>
      <root>
        <priority value="ALL" />
        <appender-ref ref="LogFileAppender" />
      </root>
    </log4net>

希望它能起作用:如果您已经显式地调用了
Configure
,那么assembly属性是不必要的,事实上,因为它非常不可靠,以至于log4net何时(如果)可以处理它,我建议不要完全依赖它。只需从
应用程序开始
调用
XmlConfigurator.ConfigureAndWatch()
。感谢您的评论。我已经删除了它。@Jeroenmoster你的评论应该是答案,你让我开心!我不明白为什么log4net不能在IIS中工作,这都是assembly属性的错误,肯定是使用了
XmlConfigurator。应该使用
Application\u Start
中的ConfigureAndWatch()
public class LogHelper
{
    private static readonly ILog Log;

    static  LogHelper()
    {
        Log = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
        log4net.Config.XmlConfigurator.Configure();
    }

    public static void RegistrarLogInfo(string message)
    {
        Log.Info(message);
    }

    public static void RegistrarLogError(string message)
    {
        Log.Error(message);
    }
}