OKHttp源码相关、常见问题

OKHttp源码解析

https://www.jianshu.com/p/27c1554b7fee

Response getResponseWithInterceptorChain() throws IOException {
    // Build a full stack of interceptors.
    List<Interceptor> interceptors = new ArrayList<>();
    //在配置 OkHttpClient 时设置的 interceptors,放在第一位
    interceptors.addAll(client.interceptors());
    // 负责失败重试以及重定向
    interceptors.add(retryAndFollowUpInterceptor);
    // 桥拦截器,添加一些Header和移除一些header,例如body的contentLength是-1,则移除Content-Length这个header
    interceptors.add(new BridgeInterceptor(client.cookieJar()));
    // 负责读取缓存直接返回、更新缓存
    interceptors.add(new CacheInterceptor(client.internalCache()));
    // 负责和服务器建立连接
    interceptors.add(new ConnectInterceptor(client));
    if (!forWebSocket) {
    // 配置 OkHttpClient 时设置的 networkInterceptors
      interceptors.addAll(client.networkInterceptors());
    }
    // 负责向服务器发送请求数据、从服务器读取响应数据
    interceptors.add(new CallServerInterceptor(forWebSocket));

OkHttp解析(一)从用法看清原理

https://www.jianshu.com/p/7b29b89cd7b5

OkHttp解析(二)网络连接

https://www.jianshu.com/p/da071ad21b6d

面试必备-源码系列 OkHttp3

https://www.jianshu.com/p/7c2bb28ccac4

OKHTTP之缓存配置详解

https://blog.csdn.net/briblue/article/details/52920531

okhttp连接池复用机制

https://blog.csdn.net/tangjiean/article/details/51729371

OkHttp3的连接池及连接建立过程分析(上篇)

https://sq.163yun.com/blog/article/188729834576564224

Okhttp3拦截器-应用拦截器和网络拦截器的区别

https://www.pianshen.com/article/7635452443/

在Okhttp3中拦截器分为应用拦截器和网络拦截器,两者有很大的区别,在使用时一定要注意防止用错造成不必要的麻烦,接下来我将说明这两个拦截器的差异.

首先看看Okhttp执行流程图,拦截器执行过程

ae7cdfa1be6930e31daac73a1555dc7d.png

再看拦截器执行顺序图

2ef8645d62e839aee480a8940c2f1182.png

根据上面的两张图,我们可以列出Application Interceptor和Network Interceptor的执行流程图

7efce340c03d726ac4f8b3d43b3f2b98.png

应用拦截器:

  • 不需要关心是否重定向或者失败重连
  • 应用拦截器只会调用一次,即使数据来源于缓存
  • 只考虑应用的初始意图,不去考虑Okhhtp注入的Header比如:if-None-Match,意思就是不管其他外在因素只考虑最终的返回结果
  • 根据第二张图我们可以看出,自定义的应用拦截器是第一个开始执行的拦截器,所以这句话的意思就是,应用拦截器可以决定是否执行其他的拦截器,通过Chain.proceed().
  • 和上一句的意思差不多,可以执行多次调用其他拦截器,通过Chain.proceed().

网络拦截器:

  • 根据第三张图,我们可以理解这句话的意思是,网络拦截器可以操作重定向和失败重连的返回值
  • 根据第一张图,我们可以以看出,这句换的意思是,取缓存中的数据就不会去还行Chain.proceed().所以就不能执行网络拦截器
  • 意思是通过网络拦截器可以观察到所有通过网络传输的数据
  • 根据第二张图我们可以看出,请求服务连接的拦截器先于网络拦截器执行,所以在进行网络拦截器执行时,就可以看到Request中服务器请求连接信息,因为应用拦截器是获取不到对应的连接信息的。

猜你喜欢

转载自blog.csdn.net/cpcpcp123/article/details/115249049