我们在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)
{
// ...
}
}
答案 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);