Retrofit 流程分析

本文详细介绍了Retrofit 2.0的核心组件及其工作原理,包括动态代理、请求构建及响应处理等关键流程。同时深入探讨了Retrofit的设计模式与架构特点。

Retrofit(2.0.0-beta3)

简介
UML

Retrofit.png
主要类介绍

  1. Retrofit
    框架入口,记录CallAdapter.Factory,Converter.Factory和网络引擎okHttpClient,完成动态代理

  2. RequestBuilder
    用于整个请求的构建,包括方法(GET,POST…)、baseUrl、relativeUrl、请求头、contentType等

  3. Response
    返回结果,包括返回码(code)、信息(message)、实体(body),内部持有okhttp3.Response和ResponseBody,对okhttp的再封装

  4. Call
    请求的发起者,参考okhttp中的Call接口

  5. Callback
    请求的异步回调

  6. Converter
    将网络返回转换为对应方法的响应类型

  7. Converter.Factory
    定义Converter的工厂,如GsonConverterFactory

  8. CallAdapter
    将网络返回转换为对应方法的返回值类型

  9. CallAdapter.Factory
    定义CallAdapter的工厂,如RxJavaCallAdapterFactory

  10. ServiceMethod
    自定义ApiService中方法的代理方法对象,在这里完成注解的解析,请求的构建

  11. ParameterHandler
    自定义ApiService中每个参数有不同的注解,如Query,Field等,在ServieMethod中解析成响应名称的ParameterHandler子类,如@Field–>Filed,每个参数对应一个ParameterHandler对象;参与最后请求的构建

主要注解 <—> ParameterHandler

  1. GET
  2. POST
流程分析
代码调用
//ApiService,sample
public interface ApiService{
    @POST("xx/xxx/xxx")
    @FormUrlEncoded
    Observable<Response<T>> sample(@Field("xx") String xx);

ApiService service = new Retrofit.Builder()
    .baseUrl(url)
    .addConverFactory(GsonConverterFacotry.create())
    .addCallAdapterFactory(RxJavaCallAdapterFactory.create())
    .client(okHttpClient)
    .build()
    .create(ApiService.class)

//使用
service.sample("xxx")
    .subscrib(new Subscribetion(){
        ...
    })
}

重点解析create()方法
create.png

分析:

  1. 使用动态代理的方式,使用注解定义请求细节
  2. 主要构建过程位于ServiceMethod.Builder的build()方法中,通过对retrofit对象的引用,获取合适的Converter和CallAdapter;其中CallAdapter通过原始方法的返回类型获得,从而得到网络结果的响应类型responseType,再由responseType获取响应的Converter
  3. 解析原始方法中的方法注解,获取请求方式(GET,POST…)、请求头、表单编码/MultiPart等
  4. 解析原始方法中的参数注解,拼接原始url(GET方式)、添加表单(POST)等等,完成请求参数的预组合
  5. 创建OkhttpCall对象,最后通过CallAdapter的adapt()方法发起请求
设计艺术
  1. Builder模式

    • Retrofit的构建
    • ServiceMethod的构建
  2. 工厂模式

    • Converter的获取
    • CallAdapter的获取
  3. 动态代理模式

    • create方法
  4. 适配器模式

    • CallAdapter – 网络返回的类型转换
### Android Retrofit HTTP 请求运行流程图及示例图片 Retrofit 是一个功能强大的类型安全的 HTTP 客户端库,用于 Android 和 Java。它的核心思想是将 HTTP API 转换为接口方法调用,从而简化了网络请求的处理过程[^1]。以下是关于 Retrofit HTTP 请求运行流程图及示例图片的相关内容。 #### 1. Retrofit HTTP 请求运行流程Retrofit 的运行流程可以分为以下几个阶段: - **创建 Retrofit 实例**:通过 `Retrofit.Builder` 创建一个 Retrofit 实例。 - **定义接口**:定义一个接口,其中包含描述 HTTP 请求的方法。 - **生成服务实例**:通过 Retrofit 实例生成接口的服务实现类。 - **发起请求**:调用接口中的方法来发起网络请求。 - **处理响应**:根据返回的结果进行处理。 下图是一个简单的序列图,展示了 Retrofit 的 HTTP 请求流程: ``` Retrofit ApiService MainActivity User | | | | | | | | | 创建Retrofit实例 | | |---------------------------> | | | | | | | 调用create方法生成ApiService| | |---------------------------->| | | | | | | | 调用getUser方法 | | | |---------------->| | | | | 发起网络请求 | | | |---------------->| | | | 返回响应 | | |<----------------| | | | 返回用户信息 | | |<----------------------------| | | 显示用户信息 | | |-------------------------------------------->| ``` 此图详细描述了从创建 Retrofit 实例到最终显示用户信息的完整流程[^2]。 #### 2. 示例代码 以下是一个使用 Retrofit 进行 HTTP 请求的简单示例代码: ```java // Step 1: 创建 Retrofit 实例 Retrofit retrofit = new Retrofit.Builder() .baseUrl("https://api.example.com/") // 设置基础 URL .addConverterFactory(GsonConverterFactory.create()) // 添加 Gson 转换器 .build(); // Step 2: 定义接口 public interface ApiService { @GET("users/{user}") Call<User> getUser(@Path("user") String userId); } // Step 3: 生成服务实例并发起请求 ApiService apiService = retrofit.create(ApiService.class); Call<User> call = apiService.getUser("12345"); call.enqueue(new Callback<User>() { @Override public void onResponse(Call<User> call, Response<User> response) { if (response.isSuccessful()) { User user = response.body(); // 处理返回的用户信息 } } @Override public void onFailure(Call<User> call, Throwable t) { // 处理请求失败的情况 } }); ``` #### 3. 更多资源 如果需要更详细的流程图或源码分析,可以参考相关博客文章或官方文档。例如,一篇深入分析 Retrofit 源码的文章提供了详细的流程图和注释[^1]。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值