Retrofit 入门

Retrofit 简介

Retrofit 是 Square 公司基于 Restful 风格推出的网络框架封装。
Retrofit 与 OKHttp 的关系:Retrofit 是基于 OKHttp 的网络请求框架的二次封装,其本质仍是 OkHttp。

常见网络库的对比:

  • AndroidAsynHttp:基于 HttpClient,作者已停止维护,Android 5.0 不再使用 HttpClient,因此不推荐使用。
  • Volley:基于 HttpUrlConnection,Google 官方推出,只适合轻量级网络交互,不适合大文件上传下载场景。
  • Retrofit:API 设计简单易用,注解化配置高度解耦,支持多种解析器,支持 RxJava。

使用步骤

1. 依赖包导入

dependencies {
    ...
    implementation 'com.squareup.retrofit2:retrofit:2.6.2'
    implementation 'com.squareup.okhttp3:okhttp:4.2.2'
    implementation 'com.squareup.retrofit2:converter-gson:2.6.2'
}

2. 网络权限

网络权限:

<uses-permission android:name="android.permission.INTERNET" />

3. 创建接口设置请求类型与参数

public interface UserMgrService {
  @GET("login)
  public Call<UserInfoModel> login(@Query("username") String username, @Query("pwd") String pwd);
}

常用参数注解:

  • @GET、@POST:确定请求方式
  • @Path:请求 URL 的字符替代
  • @Query:要传递的参数
  • @QueryMap:包含多个 @Query 注解参数
  • @Body:添加实体类对象
  • @FormUrlEncoded:URL 编码

4. 创建 Retrofit 对象设置数据解析器

Retrofit retrofit = new Retrofit.Builder().baseUrl(Constants.BASE_URL).addConverterFactory(GsonConverterFactory.create()).build();

常用数据解析器:

  • Gson:implementation 'com.squareup.retrofit2:converter-gson:(insert latest version)'
  • Jackson:implementation 'com.squareup.retrofit2:converter-jackson:(insert latest version)'
  • Simple XML:implementation 'com.squareup.retrofit2:converter-simplexml:(insert latest version)'
  • Protobuf:implementation 'com.squareup.retrofit2:converter-protobuf:(insert latest version)'
  • Moshi:implementation 'com.squareup.retrofit2:converter-moshi:(insert latest version)'
  • Wire:implementation 'com.squareup.retrofit2:converter-wire:(insert latest version)'
  • Scalars:implementation 'com.squareup.retrofit2:converter-scalars:(insert latest version)'

5. 生成接口调用接口方法

// 生成接口对象
UserMgrService service = retrofit.create(UserMgrService.class);
// 调用接口方法返回 Call 对象
Call<UserInfoModel> call = service.login("zhangsan", "123456");

6. 返送请求处理返回数据

发送请求(同步/异步):

  • 同步:调用 Call 对象的 execute(),返回结果的响应体。
  • 异步:调用 Call 对象的 enqueue(),参数是一个回调。

案例

介绍如何使用Retrofit实现用户登录。

interface UserMgrService {
    @GET("user")
    fun login(@Query("username") username: String, @Query("pwd") pwd: String): Call<UserInfoModel>
}
// 1. 创建 Retrofit 对象
val retrofit = Retrofit.Builder().baseUrl("").addConverterFactory(GsonConverterFactory.create()).build()

// 2. 获取 UserMgrService 对象
val service = retrofit.create(UserMgrService::class.java)

// 3. 调用登录方法
val call = service.login("zhangsan", "123456")

// 4. 发送请求
// 同步方式发送请求
val response = call.execute() // 注意,不能直接在主线程中执行网络请求,否则会报 NetworkOnMainThreadException 异常(Android 4.0 后强制抛出的异常)。可新建线程去执行网络请求

// 异步方式发送请求
call.enqueue(object : Callback<UserInfoModel> {
    override fun onFailure(call: Call<UserInfoModel>, t: Throwable) {
        TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
    }

    override fun onResponse(call: Call<UserInfoModel>, response: Response<UserInfoModel>) {
        TODO("not implemented") //To change body of created functions use File | Settings | File Templates.
    }
})

总结

  • Retrofit 是基于 OkHttp 网络库的高级封装
  • 采用注解,网络请求参数配置更灵活,扩展性更好
  • Restful 风格的 API 优先选用 Retrofit
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Retrofit 是什么?简单来说是用来做网络请求的,适用于 android 但又不仅是 android ,jav...
    jkwen阅读 739评论 0 1
  • Retrofit用法详解 参考:Retrofit 官方APIRetrofit用法详解(入门看这篇就够了) 一、简介...
    MryU93阅读 759评论 1 7
  • 前言 最近正在学习Retrofit,转载自这是一份很详细的 Retrofit 2.0 使用教程 中的实例讲解部分,...
    雇个城管打天下阅读 1,224评论 1 2
  • 2017.8.11可能是我今年最开心的一天,也算得上我这辈子为数不多的超级爆棚开心的一天。感恩遇到flynn和笑笑...
    aqua36阅读 554评论 0 2
  • 今天是什么日子 起床:7时 就寝:22时 天气:晴 心情:好 纪念日:无 叫我起床的不是闹钟是梦想 年度目标及关键...
    98ae0474329c阅读 350评论 5 13

友情链接更多精彩内容