Retrofit嵌套请求与适配器

一、前言:

1.        retrofit嵌套请求

在实际开发中,可能会存在:需要先请求A接口,在请求B接口的情况,比如进入“玩android”网页请求获取收藏文章列表,但是需要先登录拿到Cookie才能请求搜藏文章几口,此时请求就有了先后顺序,为了完成该功能,我们需要这样实现代码。

代码显得就很冗杂。

2.Retrofit适配器

Retrofit的接口返回的方法必须是Call,如果能够将Call改为RxJava的Observable。对于嵌套而言就得到了非常方便的解决,这就是适配器的功能。如果我们想要返回的不是Call适配器就能帮助我们转换为其他类型。

3.添加依赖:

    implementation 'com.squareup.retrofit2:adapter-rxjava3:2.9.0'

如果是Android开发还需要引入

    implementation 'io.reactivex.rxjava3:rxandroid:3.0.0'

二、代码实现

1.创建接口类对象

public interface WanAndroidService2 {

    /**
     * 学习Retrofit嵌套请求与适配器
     * 登录接口
     * @param username
     * @param pwd
     * @return
     */
    @POST("user/login")
    @FormUrlEncoded
    Flowable<BaseResponse> login2(@Field("username") String username, @Field("password") String pwd);



    /**
     * 学习Retrofit嵌套请求与适配器
     * 获取收藏文章列表
     * @return
     */
    @GET("lg/collect/list/{pageNum}/json")
    Flowable<ResponseBody> getArticle(@Path("pageNum") int pageNum);
}

2.代码实现

public class WanAndroidUnitTest {


    /**
     * 学习Retrofit嵌套请求与适配器
     */
    Map<String,List<Cookie>> cookies = new HashMap<>();//全局变量接收cookie

    Retrofit retrofit3 = new Retrofit.Builder()
            .baseUrl("https://www.wanandroid.com/")
            .callFactory((okhttp3.Call.Factory) new OkHttpClient.Builder()
                    .cookieJar(new CookieJar() {
                        @Override
                        public void saveFromResponse(@NonNull HttpUrl httpUrl, @NonNull List<Cookie> list) {
                            cookies.put(httpUrl.host(),list);
                        }

                        @NonNull
                        @Override
                        public List<Cookie> loadForRequest(@NonNull HttpUrl httpUrl) {
                            List<Cookie> cookies = WanAndroidUnitTest.this.cookies.get(httpUrl.host());
                            return cookies == null ? new ArrayList<>() :cookies;
                        }
                    }).build())
            .addConverterFactory(GsonConverterFactory.create())//添加转换器
            .addCallAdapterFactory(RxJava3CallAdapterFactory.create())//添加适配器
            .build();//创建retrofit对象
    WanAndroidService2 wanAndroidService3 = retrofit3.create(WanAndroidService2.class);//创建接口类对象,并且设置为全局变量。

    @Test
    public void rxjavaText(){
        //切换线程,如果是android请求的话必须把网络请求切换到一个子线程
        //把观察的回调切换到android的主线程,现在在java环境中。如果是在android环境中就需要把subscribeOn(Schedulers.newThread())换成.subscribeOn(AndroidSchedulers.mainThread())  。使得我们接口的回调是在主线程              .subscribeOn(AndroidSchedulers.mainThread())
        wanAndroidService3.login2("Anglin","rssqzqyp")
                .flatMap(new Function<BaseResponse, Publisher<ResponseBody>>() {
                    @Override
                    public Publisher<ResponseBody> apply(BaseResponse baseResponse) throws Throwable {
                        return wanAndroidService3.getArticle(0);
                    }
                })
                .observeOn(Schedulers.io())
                .subscribeOn(AndroidSchedulers.mainThread())
                .subscribe(new Consumer<ResponseBody>() {
                    @Override
                    public void accept(ResponseBody responseBody) throws Throwable {
                        System.out.println(responseBody.string());
                    }
                });
        while (true){}
    }
}

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Retrofit是一个基于OkHttp的RESTful风格的网络请求框架,它可以将一个HTTP API转换为Java接口。在Retrofit中,我们需要定义一个Java接口来描述HTTP API,然后通过Retrofit.create()方法来创建该接口的实例。下面是一个简单的示例: 假设我们有一个HTTP API,它的URL为https://example.com/api,请求方式为GET,请求参数为id和name,返回类型为JSON格式的字符串。那么我们可以定义一个Java接口来描述这个API: ```java public interface MyApi { @GET("/api") Call<String> getData(@Query("id") String id, @Query("name") String name); } ``` 在这个接口中,我们使用了@GET注解来指定请求方式和URL,使用@Query注解来指定请求参数,使用Call<String>来指定返回类型。 接下来,我们可以使用Retrofit.create()方法来创建该接口的实例: ```java Retrofit retrofit = new Retrofit.Builder() .baseUrl("https://example.com") .build(); MyApi myApi = retrofit.create(MyApi.class); ``` 在这个示例中,我们首先创建了一个Retrofit实例,并通过baseUrl()方法指定了API的基础URL。然后,我们调用create()方法来创建MyApi接口的实例。 最后,我们可以使用该实例来发起网络请求: ```java Call<String> call = myApi.getData("123", "test"); call.enqueue(new Callback<String>() { @Override public void onResponse(Call<String> call, Response<String> response) { String data = response.body(); // 处理返回数据 } @Override public void onFailure(Call<String> call, Throwable t) { // 处理请求失败 } }); ``` 在这个示例中,我们调用了MyApi接口的getData()方法来发起网络请求,并通过enqueue()方法来异步处理请求结果。在请求成功时,我们可以通过response.body()方法获取返回的数据,在请求失败时,我们可以在onFailure()方法中处理请求失败的情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值