Log4Net错误:无法找到配置部分' log4net'在应用程序的.config文件中

时间:2017-03-01 16:21:50

标签: c# config log4net class-library

我目前使用类库来存储使用log4net处理日志记录的类。该类用于其他项目。

我已经阅读了很多其他问题和答案,但我还没能解决它......

我启用了log4net的内部调试,因为它不会写入文件,这是我得到的错误:

log4net:ERROR Failed to find configuration section 'log4net' in the application's .config file. Check your .config file for the <log4net> and <configSections> elements. The configuration section should look like: <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />

这些是我的档案: log4net.config

<log4net debug="true">
    <appender name="LogFileAppender" type="log4net.Appender.FileAppender">
        <param name="File" value="Logs/log4net.log" />
        <param name="AppendToFile" value="true" />
        <layout type="log4net.Layout.PatternLayout">
        <param name="Header" value="[Header]\r\n" />
        <param name="Footer" value="[Footer]\r\n" />
        <param name="ConversionPattern" value="%d [%t] %-5p %c %m%n" />
        </layout>
    </appender>

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

的App.config

<?xml version="1.0" encoding="utf-8" ?>
    <configuration>
      <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net" />
      </configSections>

      <appSettings>
        <add key="log4net.Internal.Debug" value="true"/>
      </appSettings>

      <parameter>
        <parameterName value="@BlogId" />
        <dbType value="Int32" />
        <layout type="log4net.Layout.RawPropertyLayout">
          <key value="BlogId" />
        </layout>
      </parameter>
    </configuration>

AssemblyInfo.cs (只是最后一行)

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

Logger.cs

public class Logger : ILogger
    {
        private static ILog logger = LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);

        public Logger()
        {
            XmlConfigurator.Configure();
            logger.Info("NEW LOGGER INSTANCE CREATED");
        }
}

更新 我通过让使用我的Logger.cs的类为log4net提供自己的.config文件来修复它。现在log4net读取给定的.config文件,它可以工作。

2 个答案:

答案 0 :(得分:2)

您已经定义了log4net部分位于app.config中:

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

这意味着您应该将log4net.config的内容添加到app.config文件中。

答案 1 :(得分:0)

如果您要尝试通过log4net实现包装器,其中log4net 位于其自己的类库中,而位于主可执行文件中您的应用程序,请在包装类的静态构造函数中尝试以下操作:

static Logger()
{
    log4net.Config.XmlConfigurator.Configure(new System.IO.FileInfo
                                            (System.IO.Path.GetDirectoryName

    (System.Reflection.Assembly.GetExecutingAssembly().Location)));
}

静态构造函数解决方案可确保如果您加载类库,则配置代码将运行。

您还需要执行一些操作,将 log4net.config文件从该类库项目复制到与可执行文件相同的文件夹中。您可以在部署应用程序时手动执行此操作。但是,在调试带有类似内容的后生成步骤时(从类库项目中)自动执行此操作会将配置文件放入正确的文件夹中:

XCOPY "$(TargetDir)*.config" ".\..\..\..\..\bin\Debug" /S /Y /I
XCOPY "$(TargetDir)*.config" ".\..\..\..\..\bin\Release" /S /Y /I

// Where those paths point to the main executable /bin folders 
// and build configuration target dirs

使用这种方法的一个很好的理由是,如果您利用MEF之类的东西,则可以将记录器包装器类作为接口引入,而无需在更多情况下引用log4net。解决方案中的一个项目。您可以使用自己选择的抽象接口与记录器连接,并使用log4net作为Impl。 (桥模式)

祝你好运!