从 IoC 的角度来看,我们应该能够轻松设置和选择接口的实现。
如果我创建自定义实现ILogger
,我可以直接将它注入到没有ILoggerFactory-ILoggerProvider-ILogger
结构的控制器中吗?
通过这种方式,我可以减少设置开销,并对 Logger 进行更多控制。例如,我可以投射和访问CustomProperty
. 相反,ILoggerFactory-ILoggerProvider-ILogger
chain创建的记录器会维护一个ILogger
s的集合,我不能再访问我的CustomLogger
了。
代码如下所示。这是一个可行的解决方案吗?
定义 CustomLogger
public class CustomLogger : ILogger
{
public CustomPropertyType CustomProperty;
public CustomLogger(){...}
public IDisposable BeginScope<TState>(TState state){...}
public bool IsEnabled(LogLevel logLevel){...}
public void Log<TState>(
LogLevel logLevel,
EventId eventId,
TState state,
Exception exception,
Func<TState, Exception, string> formatter)
{
// Use some info from CustomProperty in while sending the log
}
}
设置依赖注入
public void ConfigureServices(IServiceCollection services)
{
services.AddScoped<ILogger, CustomLogger>();
//Other logic
}
访问ILogger
withCustomLogger
实现
public ExampleController(ILogger logger)
{
this.logger = logger;
this.customProperty = (CustomLogger)logger.CustomProperty;
}