无法解析 ILogger<T> Simple Injector ASP.NET Core 2.0
Cannot resolve ILogger<T> Simple Injector ASP.NET Core 2.0
我们在 ASP.NET 核心应用程序中使用了 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>
)。
但这很烦人,每次我们需要时都从工厂创建实例。
直接依赖class得到ILogger<T>
,而不是ILoggerFactory
.
会更好
那么,我如何注册 ILogger<T>
以获取实例,以防出现如下情况?
public class HelloWorldController : Controller
{
public HelloWorldController(ILogger<HelloWorldController> logger)
{
// ...
}
}
您还必须将记录器本身注册为通用类型。
我不知道简单的注入器,但这应该是正确的语法。
container.Register(typeof(ILogger<>), typeof(Logger<>), Lifestyle.Singleton);
尽管 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>
注入 non-generic ILogger
构造函数参数,其中 T
的 Logger<T>
成为记录器注入的类型。换句话说,当 HelloWorldController
依赖于 ILogger
时,它将被注入 Logger<HelloWorldController>
。这意味着您可以将 HelloWorldController
简化为以下内容:
public class HelloWorldController : Controller
{
public HelloWorldController(ILogger logger)
{
// ...
}
}
通过让您的应用程序组件依赖于 ILogger
而不是 ILogger<T>
您:
- 简化您的应用程序代码
- 简化单元测试
- 消除发生意外错误的可能性,因为不可能注入错误的记录器。
我们在 ASP.NET 核心应用程序中使用了 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>
)。
但这很烦人,每次我们需要时都从工厂创建实例。
直接依赖class得到ILogger<T>
,而不是ILoggerFactory
.
那么,我如何注册 ILogger<T>
以获取实例,以防出现如下情况?
public class HelloWorldController : Controller
{
public HelloWorldController(ILogger<HelloWorldController> logger)
{
// ...
}
}
您还必须将记录器本身注册为通用类型。 我不知道简单的注入器,但这应该是正确的语法。
container.Register(typeof(ILogger<>), typeof(Logger<>), Lifestyle.Singleton);
尽管 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>
注入 non-generic ILogger
构造函数参数,其中 T
的 Logger<T>
成为记录器注入的类型。换句话说,当 HelloWorldController
依赖于 ILogger
时,它将被注入 Logger<HelloWorldController>
。这意味着您可以将 HelloWorldController
简化为以下内容:
public class HelloWorldController : Controller
{
public HelloWorldController(ILogger logger)
{
// ...
}
}
通过让您的应用程序组件依赖于 ILogger
而不是 ILogger<T>
您:
- 简化您的应用程序代码
- 简化单元测试
- 消除发生意外错误的可能性,因为不可能注入错误的记录器。