Android网络请求模块------Retrofit配合Rxjava的使用

《Android网络请求框架------Retrofit的使用1》中,简单介绍了Retrofit的基本使用,本节就介绍一下Rxjava配合Retrofit的使用。

在使用之前,首先添加Rxjava的依赖

implementation 'io.reactivex.rxjava2:rxjava:2.1.0'
implementation 'io.reactivex.rxjava2:rxandroid:2.0.1'
implementation 'com.squareup.retrofit2:adapter-rxjava2:2.7.1'

在Retrofit加载的接口中,就不再使用Call对象,使用Observable对象。

@GET("getAppConfig.php")
    Observable<DataBean> getData(
            @Query("appid") String appid
    );

和Call对象做一下对比:

 @GET("getAppConfig.php")
    public Call<DataBean> getData(
            @Query("appid") String appid
    );

在创建Retrofit对象的时候,要添加RxJava适配平台;这个时候,去加载接口中的方法,将不再是得到Call对象,而是得到一个Observable对象,这个Observable对象会将请求的结果通过onNext()方法发出,然后将数据回调,剩下的步骤和之前纯Retrofit基本一致。

 Retrofit retrofit = new Retrofit.Builder()
                .baseUrl(Constant.BASE_URL_GET)
                .addConverterFactory(GsonConverterFactory.create())
                .addCallAdapterFactory(RxJava2CallAdapterFactory.create())
                .build();
        DataService dataService = retrofit.create(DataService.class);
        Observable<DataBean> observable = dataService.getData(appid);
        observable.subscribeOn(Schedulers.io())
                .subscribe(new Consumer<DataBean>() {
                    @Override
                    public void accept(DataBean dataBean) throws Exception {
                        String url = dataBean.getUrl();
                        callback.complete(url);
                    }
                });

在接口类中,还支持Response类,如下:

@GET("getAppConfig.php")
    Observable<Response<DataBean>> getData2(
            @Query("appid") String appid
    );

那么最终得到的就是一个Response对象,可以根据body得到对应的参数。

 public void loadData(String appid, DataCallback callback) {
        Retrofit retrofit = new Retrofit.Builder()
                .baseUrl(Constant.BASE_URL_GET)
                .addConverterFactory(GsonConverterFactory.create())
                .addCallAdapterFactory(RxJava2CallAdapterFactory.create())
                .build();
        DataService dataService = retrofit.create(DataService.class);
        Observable<Response<DataBean>> observable = dataService.getData2(appid);
        observable.subscribeOn(Schedulers.io())
                .subscribe(new Consumer<Response<DataBean>>() {
                    @Override
                    public void accept(Response<DataBean> dataBeanResponse) throws Exception {
                        DataBean body = dataBeanResponse.body();
                        Log.e("TAG","body==="+body.toString());
                        callback.complete(body.getUrl());
                    }
                });
    }

那么为什么喜欢RxJava呢?因为它的操作符,灵活运用这些操作符,就可能让我们的功能实现地更加简单,在后续的章节中,会陆续介绍这些操作符的用法。

发布了15 篇原创文章 · 获赞 5 · 访问量 627

猜你喜欢

转载自blog.csdn.net/qq_33235287/article/details/104227321