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(); } });
@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) { //处理返回数据 } });