使用Retrofit + RxJava 网络请求

     Android网络请求框架是Android开发中必须使用的,个人用过的网络请求框架有Android-async-http,Volley,Okhttp,以及本篇所介绍的Retrofit,我们不能用绝对的眼光去衡量这几个框架的优缺点,目前市场上使用最少的是Android-async-http近几年比较流行的就是Retrofit,但个人更认为,适合自己的才是最好的,没有必要为了让自己的代码看起来高大尚而去舍本逐末。

  1.简介

       Retrofit: Retrofit是Square 公司开发的一款正对Android 网络请求的框架。底层基于OkHttp 实现,OkHttp 已经得到了google 官方的认可。

  • 准确来说,Retrofit 是一个 RESTful 的 HTTP 网络请求框架的封装。
  • 原因:网络请求的工作本质上是 OkHttp 完成,而 Retrofit 仅负责 网络请求接口的封

 2.使用

    2.1  使用前我们要引入使用的库,在app build.gardle中添加:(注意:如果不使用Rxjava,可不引入rx的包)

implementation 'com.squareup.retrofit2:retrofit:2.1.0'
//retrofit
implementation 'com.google.code.gson:gson:2.6.2'
//Gson 库
//下面两个是RxJava 和RxAndroid
implementation 'io.reactivex:rxjava:1.1.0'
implementation 'io.reactivex:rxandroid:1.1.0'
implementation 'com.squareup.retrofit2:converter-gson:2.1.0'
//转换器,请求结果转换成Model
implementation 'com.squareup.retrofit2:adapter-rxjava:2.1.0'

 2.2   使用

  get请求

   创建Retrofit实例
Retrofit retrofit = new Retrofit.Builder()
        .baseUrl(BASE_URL)
        .addConverterFactory(GsonConverterFactory.create())
        .build();

     Retrofit 使用baseurl和请求路径分离,便于管理,比如服务端下的路径为:http://115.159.110.50/lovedog/....

  那么baseurl就是http://115.159.110.50/lovedog/,现在我们请求获取所有宠物信息,具体url为:http://115.159.110.50/lovedog/getdogall/getnewsJson.php

   定义接口
public interface GetMessage {
    @GET("getdogall/getnewsJSON.php")
    Call<List<Dog>> getdog(@Query("id") int id);
}

说明:定义了一个方法"getdogall/getnewsJson.php,使用get请求方式,加上@GET 标签,标签后面是这个接口的 尾址getdogall/getnewsJson.php,完整的地址应该是 baseUrl+尾址 ,参数 使用@Query标签,如果参数多的话可以用@QueryMap标签,接收一个Map,如果不需要参数()即可。

  Call<>中代表返回的信息类型,一般是一个实体类,因为我们返回的是一个json数组每一个jsonobject是一个Dog对象,返回的信息是Dog类型的List集合(注意:个人测试的接口返回格式不标准,通常情况下标准格式为“{code:'200',message:'success',data:[{}]}”)


   这里Dog实体类不在给出,大家可以使用GsonFormat直接生成。

   用Retrofit 创建 接口实例getmessage,并且调用接口中的方法进行网络请求,代码如下:
GetMessage getMessage = retrofit.create(GetMessage.class);
Call<List<Dog>> call = getMessage.getdog();
call.getdog(new Callback<List<Dog>>() {
    @Override
    public void onResponse(Call<List<Dog>> call, Response<List<Dog>> response) {
        Toast.makeText(MainActivity.this,response.body().toString(),Toast.LENGTH_SHORT).show();
        Log.d("请求结果",response.body().toString());
    }

    @Override
    public void onFailure(Call<List<Dog>> call, Throwable t) {
        t.printStackTrace();
        Toast.makeText(MainActivity.this,t.toString(),Toast.LENGTH_SHORT).show();
    }
});
(引用)说明:使用POST 请求方式时,只需要更改方法定义的标签,用@POST 标签,参数标签用 @Field 或者@Body或者FieldMap, 注意:使用POST 方式时注意2点,1,必须加上 @FormUrlEncoded标签,否则会抛异常。2,使用POST方式时,必须要有参数,否则会抛异常。
  @FormUrlEncoded
  @POST("top250")   Call<List<Dog>> getdog (@Query("id") int id);
3.结合RxJava使用

定义的接口,返回值不再是一个Call ,而是返回的一个Observble.

public interface GetMessage {
    @GET("getdogall/getnewsJSON.php")
    Observable<List<Dog>> getdog();
}

创建Retrofit 的时候添加如下代码

addCallAdapterFactory(RxJavaCallAdapterFactory.create())
Subscription subscription =
         getMessage.getdog()
                 .subscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe(new Subscriber<List<Dog>>(){
                    @Override
                    public void onCompleted() {
                    }
                    @Override
                    public void onError(Throwable e) {

                    }
                    @Override
                    public void onNext(List<Dog>> list) {
                        //处理返回数据
                    } });
 RxJava 的好处是帮我处理线程之间的切换,我们可以在指定订阅的在哪个线程,观察在哪个线程。我们可以通过操作符进行数据变换。整个过程都是链式的,简化逻辑。其中FlatMap 操作符 还可以解除多层嵌套的问题。总之,RxJava 很强大,能帮我处理很多复杂的场景,如果熟练使用的话,那么能提升我们的开发效率.
   Retrofit+RxJava实现网络请求的简单演示这样就完成了,如果每个接口都这么写的话,代码量太多,而且不优雅。所以还需要我们封装一下,有兴趣的朋友可以自行封装,有好的分享,欢迎投稿。时间匆忙,站在巨人的肩膀上,如有不足之处,请多多指教。微信公众号:



猜你喜欢

转载自blog.csdn.net/huangliniqng/article/details/80546003