gpt4 book ai didi

c# - Ninject.Extensions.Logging.Log4Net 为类/方法名称生成不正确的输出

转载 作者:行者123 更新时间:2023-11-30 18:38:30 41 4
gpt4 key购买 nike

我正在使用 Ninject 3.0.1.10 用于依赖注入(inject)并希望使用 Ninject.Extensions.Logging 3.0.1.0 log4net 1.2.11 日志记录。但是,当使用扩展而不是直接使用 log4net 时,我在日志文件中得到不同的输出。我希望输出包含执行日志记录的类/方法的名称,如下在我的 app.config 中:

<log4net>
<root>
<level value="DEBUG" />
<appender-ref ref="MyConsoleAppender" />
</root>

<appender name="MyConsoleAppender" type="log4net.Appender.ConsoleAppender">
<layout type="log4net.Layout.PatternLayout">
<conversionPattern value="%date %-5level %C{1}.%M():%L - %m%n" />
</layout>
</appender>
</log4net>

我做了一个示例项目来演示我遇到的问题,如下所示:

public class LoggingWithLog4Net
{
private readonly ILog log;

public LoggingWithLog4Net(ILog log)
{
this.log = log;
}

public void LogMessage(string message)
{
log.Debug(message);
}
}

public class LoggingWithNinject
{
private readonly ILogger log;

public LoggingWithNinject(ILogger log)
{
this.log = log;
}

public void LogMessage(string message)
{
log.Debug(message);
}
}

public class Program
{
static void Main(string[] args)
{
log4net.Config.XmlConfigurator.Configure();

NinjectSettings settings = new NinjectSettings()
{
LoadExtensions = false
};

using (IKernel kernel = new StandardKernel(settings, new Log4NetModule()))
{
kernel.Bind<ILog>()
.ToConstant(LogManager.GetLogger("*"));

LoggingWithLog4Net l4n = kernel.Get<LoggingWithLog4Net>();
LoggingWithNinject ninject = kernel.Get<LoggingWithNinject>();

l4n.LogMessage("log4net message");
ninject.LogMessage("ninject message");
}
}
}

这会产生以下输出(注意 Ninject 版本中不正确的类/方法名称):

2012-06-21 08:25:19,000 DEBUG LoggingWithLog4Net.LogMessage():21 - log4net message
2012-06-21 08:25:19,015 DEBUG Log4NetLogger.Debug():98 - ninject message

我希望第二行将 LoggingWithNinject.LogMessage():21 作为源类/方法,但 Ninject Log4NetLogger 用作源。我怎样才能正确识别来源?

最佳答案

看来我想要的是不可能的。配置的 %C{1}.%M():%L 部分导致 log4net 打印调用类的位置信息。在 log4net 版本中,您调用 Log4NetLogger 并将您的调用传递给 log4net。这意味着源将始终是 Log4NetLogger

作为折衷,我使用了以下内容:

<conversionPattern value="%date [%thread] %-5level %c - %m%n" />

这会丢失调用的方法名称和行号,但是在使用 Ninject 扩展时您会得到正确的类名,因为记录器总是由 Type 请求,默认为完整的命名空间/名称类的组合。

另一种选择是直接注入(inject) log4net.ILog 并停止使用 Ninject 扩展。

关于c# - Ninject.Extensions.Logging.Log4Net 为类/方法名称生成不正确的输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11133576/

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