30分鐘上手最火android網(wǎng)絡(luò)請(qǐng)求框架Retrofit

說(shuō)到目前最火的網(wǎng)絡(luò)請(qǐng)求庫(kù),那肯定是的非Retrofit莫屬了,如果你還不了解Retrofit如何使用,如果你想讓自己的網(wǎng)絡(luò)請(qǐng)求庫(kù)更優(yōu)雅一些,那么你來(lái)對(duì)地方了。

Retrofit與okhttp共同出自于Square公司,retrofit就是對(duì)okhttp做了一層封裝。把網(wǎng)絡(luò)請(qǐng)求都交給給了Okhttp,我們只需要通過(guò)簡(jiǎn)單的配置就能使用retrofit來(lái)進(jìn)行網(wǎng)絡(luò)請(qǐng)求了

首先在你的Grandle中引入Retrofit2.0,

https://github.com/square/retrofit 官方Git庫(kù) http://square.github.io/retrofit/ 官網(wǎng)
compile'com.squareup.retrofit2:retrofit:2.0.2'
compile 'com.squareup.retrofit2:converter-gson:2.0.0-beta3'

然后創(chuàng)建一個(gè)retrofit

Retrofit retrofit = new Retrofit.Builder().baseUrl("你的BaseUrl")
//retrofit已經(jīng)把Json解析封裝在內(nèi)部了 你需要傳入你想要的解析工具就行了 默認(rèn)支持Gson解析
.addConverterFactory("GsonConverterFactory.creat()")
.client(new OkHttpClient()).build();
HttpInterface httpStores = retrofit.create(HttpInterface.class);

ApiInterface.class相當(dāng)于是我們的接口請(qǐng)求庫(kù)
POST請(qǐng)求示例

public interface ApiInterface {
@FormUrlEncoded
@POST("login/app/user")
Call<DiaoChaBiaoRespsone> getUser(
@FieldMap Map<String, String> hashMap );
}
這里的UserInfo就是接口給你返回的Json解析實(shí)體
Call<UserInfo> call = httpStores.getUser(hashMap);

Get請(qǐng)求

public interface ApiInterface {
@GET("login/code/{uid}.html")
Call<ResponseBody> getUser(
@Path("cityId") String cityId);}
}
Call<UserInfo> call = httpStores.getUser("123456");

準(zhǔn)備完以上這些之后你是不是對(duì)這行代碼很有疑惑 HttpInterface httpStores = retrofit.create(HttpInterface.class);下面我們就來(lái)簡(jiǎn)單的說(shuō)一下 *
先上源碼

Paste_Image.png

大家一看就發(fā)現(xiàn)了 create方法返回了一個(gè)動(dòng)態(tài)代理對(duì)象,那么動(dòng)態(tài)代理是什么呢 :
---在運(yùn)行時(shí), 動(dòng)態(tài)代理類(lèi) 實(shí)現(xiàn)了一個(gè)或者一組接口,目的是,其中任何一個(gè)接口的實(shí)例的方法調(diào)用將會(huì)被指派到統(tǒng)一的另一個(gè)接口的方法中。
** InvocationHandler 中覆寫(xiě)的 invoke() 方法,在進(jìn)行原本的方法調(diào)用之前或者之后,可以做點(diǎn)事情。**
所以當(dāng)我們調(diào)用* httpStores.getUser(hashMap);*的時(shí)候其實(shí)是走了動(dòng)態(tài)代理的invoke方法,在這里Retrofit巧妙的理由注解把接口轉(zhuǎn)換成了一個(gè)HTTP請(qǐng)求

大概了解了create方法那我們就可以執(zhí)行請(qǐng)求了,最后一步

call.enqueue(new Callback<Object>() {
@Override
public void onResponse(
Call<Object> call, Response<Object> response) {
}
@Override public void onFailure(Call<Object> call, Throwable t) {
}});

到這里就是大家熟悉的了 請(qǐng)求成功Response 失敗onFailure Object就是你事先定義好的JSON解析類(lèi)了

是不是很簡(jiǎn)單而且很優(yōu)雅
當(dāng)然Retrofit的內(nèi)部實(shí)現(xiàn)更優(yōu)雅使用了很多設(shè)計(jì)模式這里推薦一位大神的文章Retrofit用到的設(shè)計(jì)模式

Retrofit還有很多功能沒(méi)有說(shuō)完,不過(guò)要是著急嘗嘗鮮的朋友上面已經(jīng)可以去試試了

下面在說(shuō)一下Okhttp的攔截器Interceptor 這真的是一個(gè)用起來(lái)非常爽的東西實(shí)現(xiàn)起來(lái)也非常簡(jiǎn)單
上代碼

public class OkhttpInterceptor implements Interceptor {
@Override
public Response intercept(Interceptor.Chain chain) throws IOException {
//取到當(dāng)前請(qǐng)求的Requset
Request oldRequest = chain.request();
//取到請(qǐng)求的URL ,對(duì)你的URL進(jìn)行修改,比如拼接一個(gè)UID什么的
//也可以使用addQueryParameter拼接參數(shù)
String url = oldRequest.url().toString()+"?="+uid;
Request newRequest = oldRequest.newBuilder()
.method(oldRequest.method(), oldRequest.body())
.url(url)
.build();
return chain.proceed(newRequest); }
}
當(dāng)然你也可以增加請(qǐng)求參數(shù)
HttpUrl.Builder urlBuilder = oldRequest.url()newBuilder()
.scheme(oldRequest.url().scheme()) .addQueryParameter("key", "value")
只需要把url里的參數(shù)改為urlBuilder就行了

當(dāng)然具體的業(yè)務(wù)需求也會(huì)遇到一些問(wèn)題比如當(dāng)我們的后臺(tái)用的是https的時(shí)候,需要用到自簽名證書(shū),而OKhttp3已經(jīng)沒(méi)有了setCertificates設(shè)置自簽名證書(shū)時(shí)怎么辦,沒(méi)關(guān)系我們還有萬(wàn)能的反射呢,下面我們就利用反射把https給過(guò)濾掉

SSLContext sc = null;
try {
sc = SSLContext.getInstance("SSL");
sc.init(null, new TrustManager[]{new X509TrustManager() {
@Override
public void checkClientTrusted(java.security.cert.X509Certificate[] chain, String authType) throws java.security.cert.CertificateException { }
@Override
public void checkServerTrusted(java.security.cert.X509Certificate[] chain, String authType) throws java.security.cert.CertificateException { }
@Override
public java.security.cert.X509Certificate[] getAcceptedIssuers() {
return null; } }
},
new SecureRandom());
} catch (Exception e) {
e.printStackTrace();
}
HostnameVerifier hv1 = new HostnameVerifier() {
@Override
public boolean verify(String hostname, SSLSession session) {
return true;
}};
String workerClassName = "okhttp3.OkHttpClient";
try {
sClient = new OkHttpClient.Builder().build();
Class workerClass = Class.forName(workerClassName);
Field hostnameVerifier = workerClass.getDeclaredField("hostnameVerifier"); hostnameVerifier.setAccessible(true);
hostnameVerifier.set(sClient, hv1);
Field sslSocketFactory = workerClass.getDeclaredField("sslSocketFactory"); sslSocketFactory.setAccessible(true);
sslSocketFactory.set(sClient, sc.getSocketFactory());

} catch (Exception e) {
e.printStackTrace();
}

當(dāng)然對(duì)于強(qiáng)大Retrofit我們現(xiàn)在只是管中窺豹,要想更深入了解的同學(xué)需要下去之后一步一步的debug慢慢研究了,不過(guò)不管怎么說(shuō)這么爽的網(wǎng)絡(luò)請(qǐng)求庫(kù)你是不應(yīng)該錯(cuò)過(guò)的了!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容