Retrofit使用详解

一、Retrofit框架

Retrofit是一种基于OkHttp的RESTful API请求框架,提供了一个轻量、易于学习和使用的API。Retrofit可以让我们通过注解为每一个请求配置请求方法、url、参数、请求头等信息,它通过动态代理技术,把java接口转化成HTTP请求,在结构上比较清晰。下面详细介绍四大注解用法。

1、@Get

注解用于指定请求类型。


@GET("https://www.myapi.com/data")
Call<ResponseBody> getData();

2、@Path

注解用于指定 URL 中变量的取值。


@GET("https://www.myapi.com/data/{id}")
Call<ResponseBody> getDataById(@Path("id") int id);

3、@Query

注解用于指定查询参数。它可以添加多个 Query 参数,只需要再写一个 @Query 即可。


@GET("https://www.myapi.com/data")
Call<ResponseBody> getDataByQuery(@Query("page") int page, @Query("count") int count);

4、@Body

注解使用一个对象作为其请求体。POST和PUT请求使用它传递实体。


@POST("https://www.myapi.com/data")
Call<ResponseBody> createData(@Body Data data); // Data对象即为请求体

二、Retrofit协程

在调用请求时,Retrofit默认是运行在主线程上的,如果在请求一些耗时的数据,可能会导致主线程卡死,出现ANR等问题。因此在这种情况下,可以选择使用协程处理请求。Retrofit的协程版本需要引入一个扩展库,下面给出具体的代码实现。


//1、在gradle中引入扩展库
implementation "com.squareup.retrofit2:retrofit:2.x.y"
implementation "com.squareup.retrofit2:converter-gson:2.x.y"
implementation 'com.jakewharton.retrofit:retrofit2-kotlin-coroutines-adapter:0.9.2'

//2、定义一个协程请求接口
interface ApiService {
    @GET("https://www.myapi.com/data")
    suspend fun getData(): ResponseBody
}

//3、使用协程调用请求
val apiService = Retrofit.Builder()
    .baseUrl(BASE_URL)
    .addConverterFactory(GsonConverterFactory.create())
    .addCallAdapterFactory(CoroutineCallAdapterFactory())
    .build().create(ApiService::class.java)

GlobalScope.launch(Dispatchers.Main) {
    try {
        val response = withContext(Dispatchers.IO) { apiService.getData() }
        //处理请求结果
    } catch (e: Exception) {
        //处理异常
    }
}

三、Retrofit下载文件

Retrofit同样支持下载文件,我们可以通过设置下载文件的地址以及回调函数来实现文件的下载,下面给出一个具体的例子。


//1、定义一个文件下载的接口
interface DownloadService {
    @Streaming
    @GET
    fun downloadFile(@Url fileUrl: String): Call
}

//2、创建下载文件时需要的OkHttp Client,并设置连接和读取超时时间
val httpClient = OkHttpClient.Builder()
    .connectTimeout(60, TimeUnit.SECONDS)
    .readTimeout(60, TimeUnit.SECONDS)
    .build()

//3、创建Retrofit对象
val retrofit = Retrofit.Builder()
    .baseUrl(baseUrl)
    .client(httpClient)
    .build()

//4、创建下载服务对象
val downloadService = retrofit.create(DownloadService::class.java)

//5、开始进行文件的下载
val downloadCall = downloadService.downloadFile(fileUrl)
downloadCall.enqueue(object : Callback {
    override fun onResponse(call: Call, response: Response) {
        //下载完成,开始处理
    }

    override fun onFailure(call: Call, t: Throwable) {
        //下载失败,进行异常处理
    }
})

四、Retrofit的所有形式

Retrofit不仅支持GET和POST请求,还支持PUT、DELETE等多种请求方式,并提供了RxJava、Java8 Lambda、协程等多种形式供我们选择。下面给出不同形式的代码实现。

1、RxJava形式


//1、定义一个接口
interface ApiService {
    @GET("https://www.myapi.com/data")
    fun getData(): Observable<ResponseBody>
}

//2、创建RxJava请求接口对象并进行请求
val apiService = Retrofit.Builder()
    .baseUrl(baseUrl)
    .addConverterFactory(GsonConverterFactory.create())
    .addCallAdapterFactory(RxJava2CallAdapterFactory.create())
    .build()
    .create(ApiService::class.java)

apiService.getData().subscribeOn(Schedulers.io())
    .observeOn(AndroidSchedulers.mainThread())
    .subscribe({
        //处理请求结果
    }, {
        //处理异常
    })

2、Java8 Lambda形式


//1、定义一个接口
interface ApiService {
    @GET("https://www.myapi.com/data")
    Call<ResponseBody> getData();
}

//2、创建Java8 Lambda请求接口对象并进行请求
ApiService apiService = new Retrofit.Builder()
        .baseUrl(baseUrl)
        .addConverterFactory(GsonConverterFactory.create())
        .build()
        .create(ApiService.class);

Call call = apiService.getData();
call.enqueue(new Callback() {
    @Override
    public void onResponse(Call call, Response response) {
        //处理请求结果
    }

    @Override
    public void onFailure(Call call, Throwable throwable) {
        //处理异常
    }
});

3、协程形式


//1、定义一个接口
interface ApiService {
    @GET("https://www.myapi.com/data")
    suspend fun getData(): ResponseBody
}

//2、使用协程请求接口
val apiService = Retrofit.Builder()
    .baseUrl(baseUrl)
    .addConverterFactory(GsonConverterFactory.create())
    .build()
    .create(ApiService::class.java)

GlobalScope.launch(Dispatchers.Main) {
    try {
        val response = withContext(Dispatchers.IO) { apiService.getData() }
        //处理请求结果
    } catch (e: Exception) {
        //处理异常
    }
}

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/186053.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-26 21:09
下一篇 2024-11-26 21:09

相关推荐

  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • Python输入输出详解

    一、文件读写 Python中文件的读写操作是必不可少的基本技能之一。读写文件分别使用open()函数中的’r’和’w’参数,读取文件…

    编程 2025-04-25
  • nginx与apache应用开发详解

    一、概述 nginx和apache都是常见的web服务器。nginx是一个高性能的反向代理web服务器,将负载均衡和缓存集成在了一起,可以动静分离。apache是一个可扩展的web…

    编程 2025-04-25
  • Java BigDecimal 精度详解

    一、基础概念 Java BigDecimal 是一个用于高精度计算的类。普通的 double 或 float 类型只能精确表示有限的数字,而对于需要高精度计算的场景,BigDeci…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25
  • 详解eclipse设置

    一、安装与基础设置 1、下载eclipse并进行安装。 2、打开eclipse,选择对应的工作空间路径。 File -> Switch Workspace -> [选择…

    编程 2025-04-25
  • git config user.name的详解

    一、为什么要使用git config user.name? git是一个非常流行的分布式版本控制系统,很多程序员都会用到它。在使用git commit提交代码时,需要记录commi…

    编程 2025-04-25
  • MPU6050工作原理详解

    一、什么是MPU6050 MPU6050是一种六轴惯性传感器,能够同时测量加速度和角速度。它由三个传感器组成:一个三轴加速度计和一个三轴陀螺仪。这个组合提供了非常精细的姿态解算,其…

    编程 2025-04-25
  • Python安装OS库详解

    一、OS简介 OS库是Python标准库的一部分,它提供了跨平台的操作系统功能,使得Python可以进行文件操作、进程管理、环境变量读取等系统级操作。 OS库中包含了大量的文件和目…

    编程 2025-04-25

发表回复

登录后才能评论