纪念这个明天比昨天更好的时代,纪念这个二胎开放的时代,对于技术日新月累的今天,各种新的网络技术也层数不穷,从老牌的HttpClient,那时还不能称之为框架;到android-async-http
,再到如今的老将Volley
;曾几何时,正是Xutils
,Afindl
等大而全的框架盛行其道的时候,如今也已经褪去了往日的辉煌,留下了无尽的悔恨暗暗孤独终老;如今新的网络框架诸如Okhttp,Retrofit等异军突起,新技术新思想如雨后春笋般冒了出来,设计模式MVP,MVVM
蒸蒸日上,Google都已经抛弃了apache
,我们还有什么理由不跟紧时代;Android都已经是N了,谁还为14以下做兼容,AS都已经2.1了谁还死守着Eclipse
;对于变化如此快的世界,我不会抱怨也不会有欣喜;默默的望着灰色的屏幕,继续敲着我未完成的代码…
来自Retrofit的官网介绍
A type-safe HTTP client for Android and Java
翻译:Android和Java的类型安全的HTTP客户端
首先简单介绍下Retrofit这个框架,Retrofit是底层是基于Okhttp的也就是说用法和Okhttp
很相似;Retrofit它是一个HTTP请求工具,和Google开发的Volley功能上非常相似,这里有Volley的源码解析,但是使用上很不相似。Retrofit使用起来更简单,Volley使用上更加原始而且符合使用者的直觉,其实我觉得如果对自己Volley封装一下也可以像Retrofit那样的简单的使用;
第一步当然是导包了,需要导入的包如下:
compile 'io.reactivex:rxjava:1.1.0'//Rx的包
compile 'io.reactivex:rxandroid:1.1.0'//Rx的包
compile 'com.squareup.retrofit2:retrofit:2.0.0-beta4'//Retrofit2所需要的包
compile 'com.squareup.retrofit2:converter-gson:2.0.0-beta4'//ConverterFactory的Gson依赖包
compile 'com.squareup.retrofit2:adapter-rxjava:2.0.0-beta4'//CallAdapterFactory的Rx依赖包
compile 'com.squareup.retrofit2:converter-scalars:2.0.0'//ConverterFactory的String依赖包
compile 'com.google.code.gson:gson:2.6.2'//Gosn解析包
这里需要值得注意的是导入的retrofit2包的版本必须要一致,否则就会报错,我跳过的坑大家就不要再跳了
首先定义我们请求的Api,我们假设是这样的
http://106.3.227.33/pulamsi/mobileLogin/submit.html
与Okhttp不同的是,Retrofit需要定义一个接口,用来返回我们的Call对象,这里示范的是Post请求:
public interface RequestSerives {
@POST("mobileLogin/submit.html")
Call getString(@Query("loginname") String loginname,
@Query("nloginpwd") String nloginpwd);
}
细心的同学可能注意到了,这段代码用了两个注解,我们一一来解答;
Retrofit提供的请求方式注解有@GET
和@POST
,参数注解有@PATH
和@Query
等,我们只介绍常用的;前两个顾名思义就是定义你的请求方式Get or Post
,后面的@PATH
指的是通过参数填充完整的路径,一般用法:
@GET("{name}")
Call getUser(@Path("name") String name) ;
这里的参数username会被填充至{name}
中,形成完整的Url请求地址,{name}
相当于一个占位符;
@Query
就是我们的请求的键值对的设置,我们构建Call对象的时候会传入此参数,
@POST("mobileLogin/submit.html")
Call getString(@Query("loginname") String loginname,
@Query("nloginpwd") String nloginpwd) ;
这里@Query("loginname")
就是键,后面的loginname
就是具体的值了,值得注意的是Get和Post请求,都是这样填充参数的;
接口写完了之后我们需要来定义Retrofit对象来进行请求了;
Retrofit retrofit = new Retrofit.Builder()
.baseUrl("http://106.3.227.33/pulamsi/")
//增加返回值为String的支持
.addConverterFactory(ScalarsConverterFactory.create())
//增加返回值为Gson的支持(以实体类返回)
.addConverterFactory(GsonConverterFactory.create())
//增加返回值为Oservable的支持
.addCallAdapterFactory(RxJavaCallAdapterFactory.create())
.build();
这里的baseurl
加上之前@POST("mobileLogin/submit.html")
定义的参数形成完整的请求地址;
addConverterFactory(ScalarsConverterFactory.create())
的意思是构建了一个返回支持,如果你的Call对象的泛型接收另外的格式需要添加另外的支持,上述代码已经列出;
接下来我们用这个Retrofit
对象创建一个RequestSerives
接口对象,也就是我们之前定义的那个接口,并且得到我们的Call对象;
RequestSerives requestSerives = retrofit.create(RequestSerives.class);//这里采用的是Java的动态代理模式
Call call = requestSerives.getString("userName", "1234"); //传入我们请求的键值对的值
利用得到的Call对象,然后我们就发出网络请求了:
call.enqueue(new Callback<String>() {
@Override
public void onResponse(Call<String> call, Response<String> response) {
Log.e("成功",response.body().toString());
}
@Override
public void onFailure(Call<String> call, Throwable t) {
Log.e("失败","失败");
}
});
请求成功会调用onResponse
方法,并且请求成功的值在response.body()
中,失败则会调用onFailure
,怎么样,是不是很简单呢。
下面我贴出完整的代码,主要是两个类RequestSerives和MainActivity;
import retrofit2.Call;
import retrofit2.http.POST;
import retrofit2.http.Query;
/**
* User: Daidingkang([email protected])
* Date: 2016-06-15
* Time: 11:22
* FIXME
*/
public interface RequestSerives {
@POST("mobileLogin/submit.html")
Call getString(@Query("loginname") String loginname,
@Query("nloginpwd") String nloginpwd);
}
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
init();
}
private void init() {
Retrofit retrofit = new Retrofit.Builder()
.baseUrl("http://106.3.227.33/pulamsi/")
.addConverterFactory(ScalarsConverterFactory.create())
.build();
RequestSerives requestSerives = retrofit.create(RequestSerives.class);
Call call = requestSerives.getString("13288453023", "654");
call.enqueue(new Callback() {
@Override
public void onResponse(Call call, Response response) {
Log.e("成功",response.body().toString());
}
@Override
public void onFailure(Call call, Throwable t) {
Log.e("失败","失败");
}
});
}
}