Android-最好用的网络库:Retrofit

一、简介

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()
                }
            })
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我橘子超酸

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值