Retrofit: Retrofit是Square 公司开发的一款正对Android 网络请求的框架。底层基于OkHttp 实现,OkHttp 已经得到了google 官方的认可。
OkHttp
完成,而 Retrofit 仅负责 网络请求接口的封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 = 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直接生成。
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);
定义的接口,返回值不再是一个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实现网络请求的简单演示这样就完成了,如果每个接口都这么写的话,代码量太多,而且不优雅。所以还需要我们封装一下,有兴趣的朋友可以自行封装,有好的分享,欢迎投稿。时间匆忙,站在巨人的肩膀上,如有不足之处,请多多指教。