/HttpClientEx

Primary LanguageC#MIT LicenseMIT

HttpClientEx

这个小项目解决如下两个问题:

  • httpclient的生命周期管理,以及附带的DNS状态刷新问题
  • 提供一些扩展方法,方便上层调用

第一个问题参考这里解决,感谢作者。

扩展方法设计上浏览了好些其它类似项目(感谢作者的辛苦劳动):

重点参考的是第三个项目,在其基础之上提供了更多的扩展方法;

使用

通过HttpClientManager正确的拿到HttpClient对象之后借助扩展方法愉快的编码即可。

示例

实例化

// 使用DI
public void ConfigureServices(IServiceCollection services)
{
    services.AddSingleton<HttpClientManager>();
}

// 或者普通实例化
private static HttpClientManager httpClientManager = new HttpClientManager();

使用不同的HttpMessageHandler

默认情况下HttpClientManager内部使用一个默认的HttpMessageHandler即HttpClientHandler。所有在此默认情况下创建的HttpClient会使用同一套设置(诸如超时时间等)。

如果你的不同场景有不用的设置需求,那么你可以注册命名HttpMessageHandler:

var handler = new MyHandler { InnerHandler = new HttpClientHandler() };
var httpClientManager = new HttpClientManager().AddHttpHandler("bing", handler);

超时

在两个粒度上提供了不同的超时设置:

  • HttpClient可以设置超时(注意,HttpClientManager本身可以设置一个超时。但该值只会影响到上面提到的那个默认HttpClient):

    public HttpClient CreateClient(string name, TimeSpan timeout, int retry = 0);

    如上,通过指定timeout参数我们便能拿到一个配置了自定义超时的httpclient对象

  • 单个请求可以设置超时。当调用具体的扩展方法进行http请求时,入参也可以指定一个timeout参数:

    using (var client  = _httpClientManager.CreateClient())
    {
        client.GetStringAsync("http://www.baidu.com", timeout: TimeSpan.FromSeconds(100));
    }

    如上,虽然默认的httpclient会使用HttpClientManager中默认的超时设置,但因为GetStringAsync方法调用时指定了新的timeout,则请求的超时时间以该值为准

参考链接

https://docs.microsoft.com/en-us/aspnet/core/fundamentals/http-requests?view=aspnetcore-5.0 https://thomaslevesque.com/2018/02/25/better-timeout-handling-with-httpclient/