Retrofit

作者: 双囍_小赵 | 来源:发表于2024-04-22 11:15 被阅读0次

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去使用

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

注解+代理使用 - 简书

相关文章

网友评论

      本文标题:Retrofit

      本文链接:https://www.haomeiwen.com/subject/yakiyrtx.html