无法解决ILogger <t> Simple Injector ASP.NET Core 2.0

时间:2018-03-15 13:22:30

标签: c# asp.net-core simple-injector serilog

我们在ASP.NET Core应用程序中使用Simple Injector。最近我们决定使用Serilog进行日志记录。

配置在Program.cs中完成,如documentation中所述。然后,为了使Simple Injector能够解析ILoggerFactory我做了类似的事情:

public void Configure(IApplicationBuilder app, IHostingEnvironment env)
{
    if (env.IsDevelopment())
    {
        app.UseDeveloperExceptionPage();
    }
    app.UseMvc();

    // As per my understanding, we force SimpleInjector to use 
    // ILoggerFactory registration from IApplicationBuilder
    container.CrossWire<ILoggerFactory>(app)
}

之后ILoggerFactory可以在我们使用它的任何地方注入。它工作正常(创建新实例ILogger<T>)。

但这很烦人,每次我们需要时都要从工厂创建实例。 最好将ILogger<T>直接放在依赖类中,而不是ILoggerFactory

那么,如何在下面的情况下注册ILogger<T>以获取实例?

public class HelloWorldController : Controller
{
    public HelloWorldController(ILogger<HelloWorldController> logger)
    {
         // ...
    }
}

2 个答案:

答案 0 :(得分:6)

虽然Alsami的答案可行,但请改用以下注册:

container.RegisterConditional(
    typeof(ILogger),
    c => typeof(Logger<>).MakeGenericType(c.Consumer.ImplementationType),
    Lifestyle.Singleton,
    c => true);

// This next call is not required if you are already calling AutoCrossWireAspNetComponents
container.CrossWire<ILoggerFactory>(app);

这个确切的例子显示在documentation

此注册允许将Logger<T>注入非泛型 ILogger构造函数参数,其中T Logger<T>成为类型记录器被注入。换句话说,当HelloWorldController取决于ILogger时,它会被注入Logger<HelloWorldController>。这意味着您可以将HelloWorldController简化为以下内容:

public class HelloWorldController : Controller
{
    public HelloWorldController(ILogger logger)
    {
         // ...
    }
}

让您的应用程序组件依赖于ILogger而不是ILogger<T>您:

  • 简化您的应用程序代码
  • 简化您的单元测试
  • 消除了发生意外错误的可能性,因为无法注入错误的记录器。

答案 1 :(得分:2)

您还必须将logger iteself注册为泛型类型。 我不知道简单的注入器,但这应该是正确的语法。

container.Register(typeof(ILogger<>), typeof(Logger<>), Lifestyle.Singleton);