asp.net-web-api - 另一个 : log4net log file isn't created

标签 asp.net-web-api log4net

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

我在这里做错了什么?

我的 AssemblyInfo.cs 文件中有这一行:

[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log4Net.config", Watch = true)]

我在应用程序启动时调用 XmlConfigurator.Configure()。在我的调试器中,我可以看到 Application_Start 被击中
并调用了 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 -> 属性 -> 始终复制。

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

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

关于asp.net-web-api - 另一个 : log4net log file isn't created,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27395498/

相关文章:

c# - Log4Net 不记录(可能未初始化)

c# - 如何在 ASP.NET MVC Web 应用程序中使用 log4net 异步登录而不用尽所有可用线程?

c# - log4net 不登录 Windows 事件查看器

interface - asp.net web api Controller 接口(interface)有什么好处吗?

asp.net - 为什么当输入很大时 asp.net 找不到合适的 apicontroller?

c# - 如何正确地重载具有多个集合参数的 WebAPI 2 Controller ?

nhibernate - 为什么 nhibernate 需要 Log4Net?

c# - Log4net GAC 问题仅在 Windows XP 上

c# - 使用自定义 DataAnnotationsModelValidatorProvider 进行服务器端验证

c# - System.Web.Http.Filters.ActionFilterAttribute 必须与 Controller 在同一项目中吗?