Retrofit内部的网络请求是okhttp
因为okhttp的请求在更新ui的时候需要手动切换到主线程;
而retrofit的出现是在okhttp上封装了一层,内部使用handle.post的方式主动切换到主线程更新ui;
okhttp支持高并发原理在于,有一个Dispatcher分发器,就是因为这个分发器,可以让其实现高并发,最高并发请求数maxrequests是64,超过64并发其他的多余的请求就会在等待队列里面,maxRequestsPerHost同一域名最大请求数5;
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.缓存拦截器(当前缓存是否失效,有时效,可自己设置)
5.连接拦截器(是否有https证书),没有证书访问https连接不行,就返回;
6.自定义拦截器(可以自己添加一些比如log拦截器等);
7.网络连接器(至此网络请求成功了整个请求就结束了);
retrofit在okhttp的基础之上使用了动态代理和线程切换的操作;
retrofit的动态代理在create()这个方法里面使用的:
Retrofit流程:
建造Builder-》create(实现动态代理)-》getPersonInfo(请求api方法)-》注解解析,url拼接-》call.enqueue(丢给okhttp,RealCall-AsyncCall切到子线程)-》返回数据enqueue(由子线程切回主线程)
Retrofit的动态代理
在请求接口上的注解@POST、@GET……等注解,在retrofit内部使用了注解(Annotation)的形式在通过Proxy.InvoketionHandler去使用
动态代理的话可以看之前的文章: