.NET Core 2.1:将ILogger注入LoggingHttpMessageHandler

问题描述

我正在尝试为添加到我的HttpRequestMessage中的HttpResponseMessage记录一个HttpClient及其serviceCollection。我遇到了来自Microsoft的LoggingHttpMessageHandler的实现,我想使用它,但是我不确定如何实现。

我正在使用Host,并在.ConfigureServices方法内部,将HttpMessageHandler添加添加HttpClient中。 但是,我收到此错误

尝试激活“ Microsoft.Extensions.Http.Logging.LoggingHttpMessageHandler”时,无法解析类型为“ Microsoft.Extensions.Logging.ILogger”的服务。

如何注入ILogger需要的LoggingHttpMessageHandler?如果最好创建自己的HttpMessageHandler,我该怎么做?

这是我到目前为止所拥有的:

public class Program
{
    public static async Task Main(string[] args)
    {
        CreateHostBuilder(args).Build().Run();
    }

    public static IHostBuilder CreateHostBuilder(string[] args) =>
        Host.CreateDefaultBuilder(args).ConfigureLogging((hostingContext,logging) =>
            {
                logging.AddConsole();
                logging.AddDebug();
            }).ConfigureServices((hostBuilderContext,serviceCollection) =>
            {
            serviceCollection.AddLogging();
            serviceCollection.AddSingleton<LoggingHttpMessageHandler>();

            serviceCollection.AddHttpClient<TokenClient>().AddHttpMessageHandler<LoggingHttpMessageHandler>();
            serviceCollection.AddHostedService<TokenWorker>();

           }).ConfigureAppConfiguration((hostingContext,config) =>
           {
                config.AddJsonFile("appsettings.json",false,true).Build();
           }).UseWindowsService();

}

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)