一、简介

Retrofit是一款由Square公司开发的网络库,但是它和OkHttp的定位完全不同。

OkHttp侧重的是底层通信的实现,而Retrofit侧重的是上层接口的封装。

事实上,Retrofit就是Square公司在OkHttp的基础上进一步开发出来的应用层网络通信库,使得我们可以用更加面向对象的思维进行网络操作。

Retrofit的项目主页地址是:https://github.com/square/retrofit。

二、使用

1、添加依赖

要想使用Retrofit,我们需要先在项目中添加必要的依赖库。编辑app/build.gradle文件,在dependencies闭包中添加如下内容:

dependencies {
    …
    implementation 'com.squareup.retrofit2:retrofit:2.6.1'
    implementation 'com.squareup.retrofit2:converter-gson:2.6.1'
}

2、添加json对应的数据对象

例如:
Retrofit会借助GSON将JSON数据转换成对象,因此这里同样需要新增一个App类,并加入id、name和version这3个字段,如下所示:

class App(val id: String, val name: String, val version: String)

3、新建接口

新建AppService接口,代码如下所示:

interface AppService {
   
    @GET("get_data.json")
    fun getAppData(): Call<List<App>>
}

这里使用了一个@GET注解,表示当调用getAppData()方法时Retrofit会发起一条GET请求,请求的地址就是我们在@GET注解中传入的具体参数。

另外,getAppData()方法的返回值必须声明成Retrofit中内置的Call类型,并通过泛型来指定服务器响应的数据应该转换成什么对象。

复杂接口地址

传入一个参数
GET http://example.com//get_data.json

    @GET("{page}/get_data.json")
    fun getData(@Path("page ") page: Int): Call<Data>

传入一系列参数
GET http://example.com/get_data.json?u=&t=

@GET("get_data.json")
fun getData(@Query("u") user: String, @Query("t") token: String): Call<Data>
    
@POST

POST http://example.com/data/create
{“id”: 1, “content”: “The description for this data” }

@POST("data/creat")
fun createData(@Body data: Data): Call<ResponseBody>

@POST对于服务器响应的数据并不关心,这个时候可以使用ResponseBody,表示Retrofit能够接收任意类型的响应数据,并且不会对响应的数据进行解析

在header中指定参数

GET http://example.com/get_data.json
User-Agent: okhttp
Cache-Control: max-age=0

@Headers("User-Agent: okhttp", "Cache-Control: max-age=0")
@GET("get_data.json")
 fun getData(): Call<Data>

4、Retrofit构建器(最佳写法)

object ServiceCreator {
   

    private const val BASE_URL = "https://api.caiyunapp.com/"

    private val retrofit = Retrofit.Builder()
        .baseUrl(BASE_URL)
        .addConverterFactory(GsonConverterFactory.create())
        .build()

    fun <T> create(serviceClass: Class<T>): T = retrofit.create(serviceClass)

    inline fun <reified T> create(): T = create(T::class.java)

}

5、使用

val appService = ServiceCreator.create<AppService>()

appService.getAppData().enqueue(object : Callback<List<App>> {
   
                override fun onResponse(call: Call<List<App>>, response: Response<List<App>>) {
   
                	//得到retrofit解析后的对象
                    val list = response.body()
                   
                   //处理逻辑
                }

                override fun onFailure(call: Call<List<App>>, t: Throwable) {
   
                    t.printStackTrace()
                }
            })