添加log4net config

时间:2016-05-16 12:50:16

标签: c# asp.net-web-api cors log4net owin-middleware

上下文

我有一个带控制器和动作的简单Web API项目。 在每个请求的标头中,我添加了一个授权令牌。 一切都按预期工作。我可以根据某些凭据请求令牌,并使用它来成功发出HTTP请求。

问题: 当我在web.config中添加以下内容时:

<log4net>
<appender name="FileAppender" type="log4net.Appender.FileAppender">
  <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
  <file value="logfile.txt" />
  <appendToFile value="true" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date: %-5level – %message%newline" />
  </layout>
</appender>
<root>
  <level value="DEBUG" />
  <appender-ref ref="FileAppender" />
</root>
</log4net>

我收到以下错误:

XMLHttpRequest cannot load http://localhost:4042/token. Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:8080' is therefore not allowed access. The response had HTTP status code 500.

如果删除log4net的配置,一切都按预期工作。

注意:我在web.config中没有任何在请求中添加标头的设置。

Startup.cs 是我指定的项目中唯一的一点:

  

app.UseCors(Microsoft.Owin.Cors.CorsOptions.AllowAll);

问题: log4net配置与预检请求有何关系? (基于我对ASP.NET框架的有限了解,我认为这是无意义的)。我错过了一个微妙的东西吗?

2 个答案:

答案 0 :(得分:1)

我查看了项目的webconfig,其中有一部分来自工作web.config

   <configSections> 
         <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" /> 
       </configSections> 
       <log4net> 
         <appender name="FileAppender" type="log4net.Appender.FileAppender"> 
          ...
        </log4net> 

也许你错过了configSection

答案 1 :(得分:0)

使用外部设置文件来避免此问题:

启动时,请致电:

XmlConfigurator.Configure();

在您的Web.config中,在appSettings中指定log4net.Config:

<add key="log4net.Config" value="Log.config" />

在Log.config文件中输入您的配置:

<log4net>
<appender name="FileAppender" type="log4net.Appender.FileAppender">
  <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
  <file value="logfile.txt" />
  <appendToFile value="true" />
  <layout type="log4net.Layout.PatternLayout">
    <conversionPattern value="%date: %-5level – %message%newline" />
  </layout>
</appender>
<root>
  <level value="DEBUG" />
  <appender-ref ref="FileAppender" />
</root>
<log4net>