Ошибка при попытке получить путь к файлу журнала log4net в C # - PullRequest
0 голосов
/ 23 ноября 2011

Я сталкиваюсь с этой ошибкой при попытке получить путь к файлу журнала log4net в C #. Это код, который я использовал.

Hierarchy hierarchy = LogManager.GetRepository() as Hierarchy; // WORKS FINE
Logger logger = hierarchy.Root;                                // WORKS FINE
FileAppender appender = logger.Appenders[0] as FileAppender;   // ERROR!!! - Index was out of range. Must be non-negative and less than the size of the collection. [0] Specified argument was out of the range of valid values.
string file = appender.File;

Похоже, что в массиве, указанном выше, нет объектов Appender. Кто-нибудь сталкивался с этим?

Мой раздел конфигурации log4net из App.config:

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

<log4net debug="true">
    <appender name="LogFileAppender" type="log4net.Appender.FileAppender,log4net" >
        <param name="File" value="C:\\SampleLog\\log.txt" />
        <param name="AppendToFile" value="true" />
        <layout type="log4net.Layout.PatternLayout,log4net">
            <param name="ConversionPattern" value="%date [%thread] %-5level %logger - %message%newline" />
        </layout>
    </appender>
    <root>
        <priority value="ALL" />
        <appender-ref ref="LogFileAppender" />
    </root>
    <category name="Sample.Form1">
        <priority value="ALL" />
    </category>
</log4net>

1 Ответ

3 голосов
/ 23 ноября 2011

Возможно, вы не загрузили свою конфигурацию. Вы звонили XmlConfigurator.Configure()?

Если это так, выполняете ли вы соответствующий код перед этим вызовом? Может быть, это так просто.

...