0

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

如果我创建自定义实现ILogger,我可以直接将它注入到没有ILoggerFactory-ILoggerProvider-ILogger结构的控制器中吗?

通过这种方式,我可以减少设置开销,并对 Logger 进行更多控制。例如,我可以投射和访问CustomProperty. 相反,ILoggerFactory-ILoggerProvider-ILoggerchain创建的记录器会维护一个ILoggers的集合,我不能再访问我的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
}

访问ILoggerwithCustomLogger实现

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

1 回答 1

0

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

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

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

于 2020-11-04T20:34:33.103 回答