无法解析ILogger <T>简单注入器ASP.NET Core 2.0

man*_*ger 5 c# simple-injector serilog asp.net-core

我们在ASP.NET Core应用程序中使用Simple Injector。最近,我们决定将Serilog用于记录目的。

按照Program.cs 文档中的说明进行配置。然后,为了使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)
}
Run Code Online (Sandbox Code Playgroud)

之后,ILoggerFactory无论我们在哪里使用它都可以注入。而且它工作正常(创建新实例ILogger<T>)。

但这很烦人,每次需要时都从工厂创建实例。最好ILogger<T>直接进入从属类,而不是ILoggerFactory

那么,如何注册ILogger<T>以获取实例,如下所示?

public class HelloWorldController : Controller
{
    public HelloWorldController(ILogger<HelloWorldController> logger)
    {
         // ...
    }
}
Run Code Online (Sandbox Code Playgroud)

Ste*_*ven 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);
Run Code Online (Sandbox Code Playgroud)

该确切示例在文档中显示

此注册允许将in注入Logger<T>非通用 ILogger构造函数参数中,Tof Logger<T>成为记录器所注入的类型。换句话说,当HelloWorldController依赖时ILogger,它将注入Logger<HelloWorldController>。这意味着您可以简化HelloWorldController以下内容:

public class HelloWorldController : Controller
{
    public HelloWorldController(ILogger logger)
    {
         // ...
    }
}
Run Code Online (Sandbox Code Playgroud)

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

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