Retrofit

Retrofit内部的网络请求是okhttp

因为okhttp的请求在更新ui的时候需要手动切换到主线程;

而retrofit的出现是在okhttp上封装了一层,内部使用handle.post的方式主动切换到主线程更新ui;

okhttp支持高并发原理在于,有一个Dispatcher分发器,就是因为这个分发器,可以让其实现高并发,最高并发请求数maxrequests是64,超过64并发其他的多余的请求就会在等待队列里面,maxRequestsPerHost同一域名最大请求数5;


retrofit责任链模式:就是7层拦截器

retrofit 7层拦截器--使用责任链模式

其中开头和结尾倒数第二可添加自定义拦截器,目的是在触发网络之前检查和数据准备好了再检查一下;

以上的拦截只要有一个不过,就会返回失败;


Retrofit网络访问流程如下:

1.首先去第一个自定义拦截器(可以用于判断请求参数是否正确-开发人员可以自己写相关逻辑)不正确就返回去,不向下请求了;

2.重试重定向拦截器:实际上是根据http请求返回来做响应

    重试:

          1.本地异常导致的重试

          2.建立socket链接出现的问题

          3.Tcp  访问代理服务器dns,返回真实的地址,需要重试

          4. 具体的网络资源建立出现的问题IOException

          5.网络服务器告知要重试:连接是正常的,读写也是正常的,但是服务器没有返回具体的body数据,返回的仅仅是一个response头部信息


如下图:严格来说408才是真的可以重试的返回码。响应头Retry-After:0表示立即重试,如果是其他数字表示超时重试。

重试重定向条件



      重定向:只是业务规则,http规定的一组3××的响应码

重定向核心:访问Host:127.0.0.1999,服务端返回一个链接: www.baidu.com,在用这个链接去访问服务器。

重定向请求只要不是PROPFIND请求,无论是post还是其他请求都要改成get请求方式,即只有PROPFIND请求才有请求体。

重定向核心



3.桥接拦截器(域名格式是否正确),不正确,就返回去;

4.缓存拦截器(当前缓存是否失效,有时效,可自己设置)

请求头中设置缓存


缓存设置各种类型


缓存条件,https是不允许做缓存的


缓存设置


代码中设置缓存




5.连接拦截器(是否有https证书),没有证书访问https连接不行,就返回;

6.自定义拦截器(可以自己添加一些比如log拦截器等);

7.网络连接器(至此网络请求成功了整个请求就结束了);

Okhttp五层拦截器,两层自定义拦截器



retrofit在okhttp的基础之上使用了动态代理和线程切换的操作;


retrofit的动态代理在create()这个方法里面使用的:

rerofit动态代理的使用


Retrofit流程:

建造Builder-》create(实现动态代理)-》getPersonInfo(请求api方法)-》注解解析,url拼接-》call.enqueue(丢给okhttp,RealCall-AsyncCall切到子线程)-》返回数据enqueue(由子线程切回主线程)


Retrofit的动态代理

在请求接口上的注解@POST、@GET……等注解,在retrofit内部使用了注解(Annotation)的形式在通过Proxy.InvoketionHandler去使用


动态代理的话可以看之前的文章:

注解+代理使用 - 简书

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容