gpt4 book ai didi

c# - Windows 窗体上的 log4net 不写入日志文件

转载 作者:行者123 更新时间:2023-11-30 20:22:37 27 4
gpt4 key购买 nike

我正在使用 .NET Framework 4.0 和 log4net 1.2.13 开发 Windows 窗体应用。

这是我第一次在 Windows 窗体应用程序中使用 log4net,但它不起作用。也许我现在忘记了一个配置步骤,它不起作用:我找不到日志文件

这就是我实例记录器的方式:

public partial class MainForm : Form
{
private static readonly log4net.ILog _logger =
log4net.LogManager.GetLogger(typeof(MainForm));

这是 App.Config 的内容:

<log4net xsi:noNamespaceSchemaLocation="http://csharptest.net/downloads/schema/log4net.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<appender type="log4net.Appender.RollingFileAppender" name="AppLogErrorAppender">
<file value="D:\\AppError.log" />
<appendToFile value="true" />
<rollingStyle value="Date" />
<datePattern value=".yyyyMMdd.lo\g" />
<maximumFileSize value="5MB" />
<maxSizeRollBackups value="-1" />
<countDirection value="1" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
</layout>
</appender>
<appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
</layout>
</appender>
<logger name="AppLog">
<level value="ERROR" />
<appender-ref ref="AppLogErrorAppender" />
</logger>
<root>
<level value="ERROR" />
<appender-ref ref="AppLogErrorAppender" />
<appender-ref ref="ConsoleAppender" />
</root>
</log4net>

我在这里登录:

public const string LogExceptionNameMessageFormatString = "EXCEPTION: {0} - Message: {1}";

private void LogError(string exceptionMessage, string exceptionName)
{
_logger.ErrorFormat(LogExceptionNameMessageFormatString, exceptionName, exceptionMessage);
}

我在上面设置了一个断点,然后它就停止了。

我做错了什么?

最佳答案

程序.cs:

[STAThread]
private static void Main(string[] args)
{
log4net.Config.XmlConfigurator.Configure();

/* other stuff */
}

我通常也会立即在 void Main 中记录一些内容, 配置后。

应用程序配置:

您需要记住将 log4net 配置部分作为 <configSections> 的第一个元素放入:

<?xml version="1.0" encoding="utf-8"?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
</configSections>
<startup>
<supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.0"/>
</startup>

<log4net>
<appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
<file value="log.log"/>
<appendToFile value="true"/>
<rollingStyle value="Size"/>
<maxSizeRollBackups value="1"/>
<maximumFileSize value="5MB"/>
<staticLogFileName value="true"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%newline%date [%thread] %-5level %logger - %message%newline%exception"/>
</layout>
</appender>

<appender name="DebugAppender" type="log4net.Appender.DebugAppender">
<immediateFlush value="true"/>
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%newline%date [%thread] %property{detailContext} %-5level %logger - %message%newline%exception"/>
</layout>
</appender>

<root>
<level value="ALL"/>
<appender-ref ref="DebugAppender"/>
<appender-ref ref="RollingFileAppender"/>
</root>
</log4net>
</configuration>

关于c# - Windows 窗体上的 log4net 不写入日志文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31111340/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com