Ste*_*ier 9 c# httpclient asp.net-core
使用HttpClientFactory.NET Core 时,是否可以以某种方式删除默认值LoggingHttpMessageHandler?
我期待像下面这样的东西,但它似乎不存在
services.AddHttpClient("minos")
.RemoveHttpMessageHandler<LoggingHttpMessageHandler>();
Run Code Online (Sandbox Code Playgroud)
您可以通过将 HttpClient 的日志级别设置为none在 appsettings.json 中配置它:
但是,这也将启用来自 System 根命名空间中所有其他组件的信息性消息。因此,最好通过将配置限制为“System.Net.Http.HttpClient”来配置日志记录,以便您仅通过通过 HttpClientFactory 创建的客户端添加来自 HTTP 请求的消息:
Run Code Online (Sandbox Code Playgroud){ "Logging": { "LogLevel": { "Default": "Warning", "System.Net.Http.HttpClient": "Information" } } }
https://www.stevejgordon.co.uk/httpclientfactory-asp-net-core-logging
对于任何需要这个的人,我在 github repo 上打开了一个问题,其中一位贡献者回复了以下内容(我仍然需要尝试一下)
foreach (var service in serviceCollection.Where(s => s.ServiceType == typeof(IHttpMessageHandlerFactory)))
{
serviceCollection.Remove(service);
}
Run Code Online (Sandbox Code Playgroud)
更新: 改用以下内容(以上内容不完全有效)
services.RemoveAll<IHttpMessageHandlerBuilderFilter>();
Run Code Online (Sandbox Code Playgroud)
https://github.com/aspnet/HttpClientFactory/issues/196#issuecomment-431440889
| 归档时间: |
|
| 查看次数: |
5291 次 |
| 最近记录: |