美文网首页Android学习日记
Android日记之Retrofit的基本使用

Android日记之Retrofit的基本使用

作者: 居居居居居居x | 来源:发表于2019-10-18 22:59 被阅读0次

前言

之前做的项目都是用okhttp框架来进行网络请求的,然后自己自行封装,虽然以前也有使用过Retrofit,但是Retrofit本质上还是对okhttp的封装,而且面试的时候也会经常的Retrofit框架的使用和原理以及它内部使用的设计模式之类的,这篇文章主要讲述如何使用Retrofit请求框架,以及一些使用的细节,毕竟是一个很灵活的使用框架,后续在写一篇关于Retrofit的源码解析和使用了哪些设计模式。

Retrofit的导入

我们主要以是2.0版本来进行讲解,第一个是Retrofit,第二个是Retrofit的Json解析,至于有什么用后面就知道了,当然换成别的Json解析也是可以的

implementation 'com.squareup.retrofit2:retrofit:2.5.0'
implementation 'com.squareup.retrofit2:converter-gson:2.5.0'

还有网络权限也要记得添加:

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

Call接口

首先它需要一个请求的Call接口来进行请求,Retrofit使用注解的方式来区分是Get请求还是Post请求等等之类的,比如:

public interface ApiService {

    @GET(".")
    Call<ResponseBody> get();
}

这就是一个很简单的get请求的接口,泛型是你要返回的Model数据的类型,当然如果你的请求地址是动态的话,可以这么写:

@GET("api/{path}")
Call<ResponseBody> get(@Path("path")int path);

Post请求的话可以这么写:

@FormUrlEncoded
@POST(".")
Call<ResponseBody> post(@Field("ip") String first);

@FormUrlEncoded表示这是一个表单的请求,传输数据类型为键值对,使用@Field注解来标示所对应的String类型数据的键,从而组成一组键值对进行传递。

当然还有其它的注解:

注解代码如图,侵删
字段注解代码如图,侵删
这里需要注意的是在@GET或者@POST的括号里面如果没有要请求的URL的话,是不能空着的,空的话默认写 . 或者 / 都是可以的,如果是空的话则会报错:
Call接口报错如图

创建Retrfit客户端对象

//创建Retrfit
Retrofit retrofit = new Retrofit.Builder()
        .baseUrl("https://wanandroid.com/wxarticle/chapters/json/")
        .addConverterFactory(GsonConverterFactory.create())
        .build();

通过Retrofit的Builder()构建者模式可以快速构建客户端以及所需要的配置,addConverterFactory()这个方法就是配置你要用哪个Gson对返回的数据进行解析。没错,这也是为什么要在Call设置泛型的原因,Retrofit是会自动进行Json解析的,然后最后返回的结果就是解析后的Response实体,这样就不用另外写解析Json的业务逻辑,大大节省了代码的行数。

这里有一个非常需要注意的点!这里填入的baseUrl()是公共的Url,后面就是跟着你自己定义接口路径的Url,这里的baseUrl()填的Url结尾一定要跟一个 / ,否则它也是会报错的(PS:这里用的请求接口是“玩Android 开放API”的公共API)。

Url报错如图

Retrofit的异步请求

//用Retrofit创建接口实例对象
ApiService apiService = retrofit.create(ApiService.class);
//获取Call对象
Call<DataModel> call = apiService.get();
//开始异步操作
call.enqueue(new Callback<DataModel>() {
    @Override
    public void onResponse(Call<DataModel> call, Response<DataModel> response) {

        Toast.makeText(MainActivity.this, response.body().getData().get(0).getName(), Toast.LENGTH_SHORT).show();
        b1.setText("请求完毕更新UI");
    }

    @Override
    public void onFailure(Call<DataModel> call, Throwable t) {

    }
});

接下来就跟okhttp的请求差不多,通过Retrofit客户端创建一个接口的实例对象,然后通过Call进行获取,最后使用enqueue()来进行异步请求返回一个Callback的回调接口,回调接口的泛型就是Retrofit客户端Json解析后的Model。

结果如图
这里我们发现了,我们是可以在回调回来的接口里面进行直接更新UI的操作的,这也就代表回调回来的接口是在主线程上面的,不像okhttp那样回调回来的接口还是在子线程上,我们还需要通过Handler来进行更新UI的操作。

返回原始Json字段

刚刚也说了,Retrofit返回过来的是已经经过Json解析过的Response对象,但是有时候Json字段是不断更新的话,你的Model也要进行相应的更新,这就需要返回原始的字段了,Retrofit本身没提供这个方法,但是毕竟是封装okhttp,它是可以返回原始的Json字段的。

@GET(".")
Call<ResponseBody> get();
//创建Retrfit
Retrofit retrofit = new Retrofit.Builder()
        .baseUrl("https://wanandroid.com/wxarticle/chapters/json/")
        .addConverterFactory(GsonConverterFactory.create())
        .build();

//用Retrofit创建接口实例对象
ApiService apiService = retrofit.create(ApiService.class);
//获取Call对象
Call<ResponseBody> call = apiService.get();
//开始异步操作
call.enqueue(new Callback<ResponseBody>() {
    @Override
    public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) {

        String json = null;
        try {
            json = response.body().string();
        }catch (Exception e){
            e.printStackTrace();
        }


        Toast.makeText(MainActivity.this, json, Toast.LENGTH_SHORT).show();
        b1.setText("请求完毕更新UI");
    }

    @Override
    public void onFailure(Call<ResponseBody> call, Throwable t) {

    }
});

其实只要把Call要传入的泛型接口改成ResponseBody就好了,对应的回调接口也要改成ResponseBody,ResponseBody是okhttp的Response的返回体,所以就可以通过string()方法返回就好了。

Json返回结果如图

参考

相关文章

网友评论

    本文标题:Android日记之Retrofit的基本使用

    本文链接:https://www.haomeiwen.com/subject/sdlwmctx.html