我们在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)
{
// ...
}
}
解决方法:
虽然SamiAl90的答案可行,但请使用以下注册:
container.CrossWire<ILoggerFactory>(app);
container.RegisterConditional(
typeof(ILogger),
c => typeof(Logger<>).MakeGenericType(c.Consumer.ImplementationType),
Lifestyle.Singleton,
c => true);
这个确切的例子显示在documentation中.
该注册允许注入Logger< T>.进入非通用的ILogger构造函数参数,其中Log of T< T>成为记录器注入的类型.换句话说,当HelloWorldController依赖于ILogger时,它将被注入一个Logger< HelloWorldController>.这意味着您可以将HelloWorldController简化为以下内容:
public class HelloWorldController : Controller
{
public HelloWorldController(ILogger logger)
{
// ...
}
}
通过让您的应用程序组件依赖于ILogger而不是ILogger< T>您:
>简化您的应用程序代码
>简化您的单元测试
>消除发生意外错误的可能性,因为无法注入错误的记录器.