深入理解HttpClient
2021-04-11 18:25
标签:span 使用 网络 方法 log success handler protected blog Httpclient的设计图: HttpClient请求过程: 从Request发起,经过DelegatingHanlder处理后,进入InnerHandler,数据返回后再从Inner Handler 返回到Delegating Hanlder进行处理,最后返回结果。 从设计角度来讲,HttpClient库提供了强大的扩展性,使用者不需要任何继承即可完成对HttpClient的扩展(如果对设计模式熟悉,可以清楚的看出这里用到了装饰器模式) 先看案例: LoggingHandler:将HttpClient请求、响应内容记录日志 代码说明: 1、HttpClient这个类本身并不会进行实际的网络请求收发处理,我们应将其理解成一个容器、一个中继者,实际的网络请求核心在HttpClientHanlder中,也就是前面图中对应的Inner Handler。 2、我们自己定义了一个LoggingHandler,这个类对应Delegating Handler 是我们自定义的、装饰在Inner Handler外的Handler 3、DelegatingHandler重载了SendAsync,在其内部调用了InnerHandler的SendAsync方法,如此我们便可以在实际请求发出,以及返回后进行各种统一的处理,总结起来仍是上面图中画出的,逐层调用。 4、HttpClientHandler、DelegatingHandler都是继承自HttpMessageHandler HttpClientHandler: DelegatingHandler: 案例2:封装一个RetryHandler,目的是失败重试 RetryHandler: 在.NET Core中,如果使用HttpClientFactory创建HttpClient,如何添加HttpMessageHandler? 需要自己去实现接口IHttpMessageHandlerBuilderFilter 参考:https://blog.csdn.net/weixin_30236595/article/details/101066107 ... 深入理解HttpClient 标签:span 使用 网络 方法 log success handler protected blog 原文地址:https://www.cnblogs.com/fanfan-90/p/12409101.htmlpublic class LoggingHandler : DelegatingHandler
{
public LoggingHandler(HttpMessageHandler handler) : base(handler) { }
protected override async Task
HttpMessageHandler handler = new HttpClientHandler();
HttpClient client = new HttpClient(new LoggingHandler(handler));
public class HttpClientHandler : HttpMessageHandler
{}
public abstract class DelegatingHandler : HttpMessageHandler
{}
public class RetryHandler : DelegatingHandler
{
private const int MAX_COUNT = 3;
protected override async Task
HttpMessageHandler handler = new HttpClientHandler();
handler = new LoggingHandler(handler);
handler = new RetryHandler(handler);
HttpClient client = new HttpClient(handler);