Ninject,如何通过调用LoggerFactory.CreateLogger注入通用Logger <t>

时间:2017-10-20 05:57:12

标签: asp.net-mvc dependency-injection ninject ninject-extensions

我正在研究ASP.NET MVC应用程序。

我已经在一个从Global.asax

调用的静态类中初始化了我的LoggerFactory
using Microsoft.Extensions.Logging;
using Serilog;
using System.IO;

namespace web
{
    public static class LogConfig
    {
        public static LoggerFactory LoggerFactory = new LoggerFactory();

        public static void RegisterLogger()
        {
            LoggerFactory = new LoggerFactory();
            Log.Logger = new LoggerConfiguration().MinimumLevel.Debug().WriteTo.RollingFile(Path.Combine("", "log-{Date}.txt")).CreateLogger();
            LoggerFactory.AddSerilog();
        }
    }
}

现在我想使用ninject,将ILogger的一个实例注入到我的构造函数中......

在我的构造函数中,我有:

private ILogger<MyTypeController> _logger;

public MyTypeController(ILogger<MyTypeController>) 
{
    // This works fine but I want to inject it
    _logger = LogConfig.LoggerFactory.CreateLogger<MyTypeController>();
}

上面的代码有效,但我想用ninject注入它...这是我尝试过的但是甚至没有编译:

kernel.Bind(typeof(ILogger<>)).ToProvider(LogConfig.LoggerFactory.CreateLogger<>());

2 个答案:

答案 0 :(得分:2)

我正在使用NLog执行以下操作,但它也可能适用于Ninject:

var createLoggerMethod =
    typeof(LoggerFactoryExtensions).GetMethod(nameof(LoggerFactoryExtensions.CreateLogger),
        new[] {typeof(ILoggerFactory)});
kernel.Bind(typeof(ILogger<>)).ToMethod(context =>
{
    var createLoggerGeneric = createLoggerMethod.MakeGenericMethod(context.GenericArguments);
    var logger = createLoggerGeneric.Invoke(null, new []{ loggerFactory });
    return logger;
});

答案 1 :(得分:0)

阅读@Steven的评论并阅读他在Simple Injector上的博客,我已经意识到注入通用记录器ILogger<T>并不是一个好方法。

有关更多详细信息,请参见this answer