如何在控制台应用程序中配置ConsoleLogger?

Jef*_*ege 6 c# .net-core asp.net-core

我正在尝试使用 .NET CORE 3.1 构建一个控制台应用程序,但在注入控制台记录器时遇到问题。

在最近的版本中,注入日志记录的方式似乎发生了显着变化,并且各种风格的教学教程似乎都不符合我想要做的事情。

我有一个界面:

public interface IMyDoer
{
    void DoSomething();
}
Run Code Online (Sandbox Code Playgroud)

以及我想要注入 ILogger 的类:

public class MyDoer : IMyDoer
{
    private readonly ILogger logger;
    public MyDoer(ILogger logger)
    {
        this.logger = logger;
    }

    public void DoSomething()
    {
        this.logger.Log(LogLevel.Information, "Doing something");
    } 
}
Run Code Online (Sandbox Code Playgroud)

然后我有我的 Main(),我在其中尝试配置 DI 容器来构造 Doer 对象,配置 ILogger 以登录到控制台。

public class Program
{
    public static void Main(string[] args)
    {
        var serviceCollection = new ServiceCollection();
        ConfigureServices(serviceCollection);

        var serviceProvider serviceCollection.BuildServiceProvider();

        var myDoer = serviceProvider.GetService<IMyDoer>();

        myDoer.DoSomething();
    }

    private static void ConfigureServices(ServiceCollection serviceCollection)
    {
        serviceCollection.AddLogging(configure => {
            configure.AddConsole();
        });

        serviceCollection.AddSingleton<IMyDoer, MyDoer>();
    }
}
Run Code Online (Sandbox Code Playgroud)

作为替代方案,我尝试过:

public class Program
{
    static void Main(string[] args)
    {
        var serviceCollection = new ServiceCollection();
        ConfigureServices(serviceCollection);

        using (var serviceProvider = serviceCollection.BuildServiceProvider())
        using (var loggerFactory = LoggerFactory.Create(builder => builder.AddConsole()))
        {
            var myDoer = serviceProvider.GetService<IMyDoer>();

            myDoer.DoSomething();
        }
    }

    private static void ConfigureServices(ServiceCollection serviceCollection)
    {
        serviceCollection
            .AddSingleton<IMyDoer, MyDoer>();
    }
}
Run Code Online (Sandbox Code Playgroud)

无论哪种情况,我都会遇到异常:

System.InvalidOperationException
  HResult=0x80131509
  Message=Unable to resolve service for type 'Microsoft.Extensions.Logging.ILogger' while attempting to activate 'MyDoer.DoSomething'.
  Source=Microsoft.Extensions.DependencyInjection
Run Code Online (Sandbox Code Playgroud)

关于我该如何做这件事有什么想法吗?

Kir*_*kin 1

ILogger未向 ASP.NET Core DI 容器注册。相反,使用ILogger<T>

public class MyDoer : IMyDoer
{
    private readonly ILogger<MyDoer> logger;

    public MyDoer(ILogger<MyDoer> logger)
    {
        this.logger = logger;
    }

    // ...
}
Run Code Online (Sandbox Code Playgroud)

ILogger<T>使用类型名称 ( YourNamespace.MyDoer) 作为日志类别

该类别包含在该实例创建的每条日志消息中ILogger

要设置您自己的日志类别并创建您自己的实现ILogger,请使用ILoggerFactory

public class MyDoer : IMyDoer
{
    private readonly ILogger logger;

    public MyDoer(ILoggerFactory loggerFactory)
    {
        this.logger = loggerFactory.CreateLogger("YourCategory");
    }

    // ...
}
Run Code Online (Sandbox Code Playgroud)