gpt4 book ai didi

c# - 如何在保存为文本文件时向 Log4Net 添加参数

转载 作者:行者123 更新时间:2023-11-30 21:34:56 25 4
gpt4 key购买 nike

我使用 log4net.Appender.RollingFileAppender。

我将我的日志保存到一个文本文件中。我想自定义属性值。

            <log4net debug="true">
<appender name="file" type="log4net.Appender.RollingFileAppender, log4net">
<file value="Log.txt" />
<appendToFile value="true" />
<rollingStyle value="Size" />
<maxSizeRollBackups value="10" />
<maximumFileSize value="1MB" />
<staticLogFileName value="true" />
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date [%thread] %level %logger [%property{NDC}] - %message%newline" />
</layout>
</appender>
<root>
<level value="ALL" />
<appender-ref ref="file" />
</root>
</log4net>

这是我的课:

public static class log4netPark
{
private static ILog _logger = null;

private static log4net.ILog Logger
{
get
{
if (_logger == null)
{
_logger = LogManager.GetLogger(typeof(log4netPark));
log4net.Config.XmlConfigurator.Configure();
}
return _logger;
}
}

public static void Info(string Message, LogType tip)
{
Logger.Info(Message);
}

public static void Error(string Message, Exception ex, LogType tip)
{
Logger.Error(Message, ex);
}
}

就是这样保存到txt文件中的。

2018-04-05 18:37:23,772 [1] INFO IK_DL.log4netPark [(null)] - 用户已登录。

我尝试将此代码块放入 Info 方法中,但其中任何一个都不起作用:

GlobalContext.Properties["LOG_TYPE"] = 3;
GlobalContext.Properties["name"] = "tryThisOne";
ThreadContext.Stacks["logger"].Push("LoggerNameTrying");
LogicalThreadContext.Properties["&thread"] = 13;

在使用AdoNetAppender的时候,我们可以添加参数。是否可以使用 RollingFileAppender 或我可以使用 codeblockS 来做到这一点?

最佳答案

您必须在格式字符串中提及属性。因此,如果您希望打印“LOG_TYPE”属性,请更改您的模式:

<conversionPattern value="... [%property{LOG_TYPE}] - %message%newline" />

关于c# - 如何在保存为文本文件时向 Log4Net 添加参数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49688305/

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