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

时间:2012-06-21 07:35:05

标签: c# log4net ninject ninject-extensions

我正在使用Ninject 3.0.1.10进行依赖注入,并希望将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作为源。如何才能正确识别源?

1 个答案:

答案 0 :(得分:0)

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

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

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

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

另一种方法是直接注入log4net.ILog并停止使用Ninject扩展。