繁体   English   中英

我可以在没有 LoggerFactory 的情况下直接注入 ILogger

[英]Can I directly Inject ILogger without LoggerFactory

从 IoC 的角度来看,我们应该能够轻松设置和选择接口的实现。

如果我创建ILogger自定义实现,是否可以将它直接注入控制器而不使用ILoggerFactory-ILoggerProvider-ILogger结构?

通过这种方式,我可以减少设置开销并更好地控制 Logger。 例如,我可以投射和访问CustomProperty 相比之下,由ILoggerFactory-ILoggerProvider-ILogger链创建的记录器将维护一个ILogger的集合,我无法再访问我的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
}

使用CustomLogger实现访问ILogger

public ExampleController(ILogger logger)
{
    this.logger = logger;
    this.customProperty = (CustomLogger)logger.CustomProperty;
}

是的,您需要提供者。 您可以将其添加到 .NET Core 应用程序的Startup类中。 此类代码应如下所示:

loggerFactory.AddProvider(new CustomLoggerProvider(new CustomLoggerConfiguration()));

是对这种用法的解释。 是一个例子。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM