RxRetroHttp為多套API請求適配而生
前言
"后端更新?lián)Q代,新接口返回全用新的規(guī)則,老接口不變!"。。。WTF!
“我們的這幾個網(wǎng)站,要做一個統(tǒng)一的App,后端都是現(xiàn)成的,這是API文檔。”。。。幾個網(wǎng)站的API規(guī)范和請求Host地址居然完全不一樣?。。。WTF!
實時切換BaseUrl?Retrofit注解全加上@Url?。。。無奈。。。
雖然說現(xiàn)在已經(jīng)有很多Http請求框架了,也有很多針對RxJava+Retrofit的二次封裝,其中也不乏很多動態(tài)替換BaseUrl的框架。但是如果需要更好的處理除了BaseUrl之外需求,比如針對各套API規(guī)則,不同的攔截處理、不同的返回異常邏輯處理等等,大多沒有給予解決方案。因此,RxRetroHttp應(yīng)運而生。
總覽
我們先來看看,RxRetroHttp是通過什么方式處理這種情況的。
初始化
首先,大多庫的必備階段:初始化。我們先來看看初始化的代碼,在Application的onCreate中執(zhí)行
RxRetroHttp.init(this)
.setBaseUrl("http://api1.com/")
.setApiResultClass(Api1Result.class)
.generateRetroClient()這樣,初始化就做完了。。。此處應(yīng)有掌聲。。。
說好的處理多套API規(guī)則呢?。?!”
額咳。。??陀^莫急。。。待我徐徐道來
通過剛剛的初始化,你已經(jīng)設(shè)置了App中主API請求的基本配置。如果你的App中,就像前言里描述的那樣,需要對接多套API規(guī)則,那么在初始化之后,再加入如下代碼
RxRetroHttp.getInstance()
.setBaseUrl("https://api2.com/")
.setApiResultClass(Api2Result.class)
.generateRetroClient("API2")相信大家已經(jīng)看出區(qū)別了吧,沒錯,就是在generateRetroClient這個方法中,加入了一個Tag,而這個Tag,就是處理多套API請求的關(guān)鍵。
在setApiResultClass方法中,傳入的就是對于API規(guī)范的基類,具體情況會在后面講到。
調(diào)用
初始化完成后,如何調(diào)用呢
RxRetroHttp.create(Api2Service.class).getApi2Info()
我們可以看到,這就是Retrofit風(fēng)格的調(diào)用方式。
在這里,Api2Service也就是Retrofit風(fēng)格的ApiService,但是也略有不同
@RetroTag("API2")
public interface Api2Service {
@GET("test/info")
Observable<Api2Info> getApi2Info();
}我們看看不同在哪,下面是純Retrofit的書寫方式
public interface Api2Service {
@GET("test/info")
Observable<Api2Result<Api2Info>> getApi2Info();
}沒錯,區(qū)別就在于:
1、省去了基類的這一層包裹。這么做的原因是,個人認(rèn)為,在ApiService這一層,每個接口定義都需要設(shè)置ApiResult包裹是不人性的,哈哈哈。
2、RetroTag接口,用于指示Tag,當(dāng)然這是對于初始化時設(shè)置了Tag的API請求。
當(dāng)然,如果你還是希望以基類包裹的方式,也是可以的,那就是在初始化的時候,不調(diào)用setApiResultClass方法就行了。
另外,如果你不想增加RetroTag注解,也是可以的,那在調(diào)用的時候,就需要調(diào)用另一個方法,放入Tag,如下:
RxRetroHttp.create(Api2Service.class, "API2").getApi2Info()
ApiResult
現(xiàn)在,我們來看看ApiResult。
在setApiResultClass方法中傳入的,是實現(xiàn)了IApiResult接口的請求返回基類,簡單的樣例代碼如下
public class Api2Result<T> implements IApiResult<T> {
private int code;
private String msg;
private T result;
@Override
public boolean isSuccess(){
return code == 1;
}
@Override
public T getData(){
return result;
}
@Override
public String getResultMsg(){
return msg;
}
@Override
public String getResultCode(){
return String.valueOf(code);
}
@Override
public String getDataField(){
return "result";
}
}其對應(yīng)的返回json如下
{
code: 1,
msg: "請求成功",
result: {
...
}
}這是一個較為常用的API返回格式,而我們所要做的,就是實現(xiàn)幾個基本方法,其中,isSuccess()返回的是請求成功的判斷,getData()返回的是請求到的具體數(shù)據(jù),getResultMsg()返回的是API請求信息,getResultCode()表示返回碼,getDataField()返回的是json數(shù)據(jù)中表示具體數(shù)據(jù)的字段(在上面的json例子中,就是“result”)。
更多配置
Http請求不可能沒有相關(guān)的配置,而本框架并沒有為大家內(nèi)置很多配置方法,原因是,我認(rèn)為這并不是本框架的主要功能。當(dāng)然,大家也是可以進行自定義配置的,配置方式如下:
RxRetroHttp.init(this).setXXX().setXXX();
Retrofit.Builder retrofitBuilder = RxRetroHttp.getRetrofitBuilder();
retrofitBuilder.setXXX().setXXX();
OkHttpClient.Builder okHttpBuilder = RxRetroHttp.getOkHttpClientBuilder();
okHttpBuilder.setXXX().setXXX();
RxRetroHttp.getInstance().generateRetroClient();
//RxRetroHttp.getInstance().generateRetroClient("YourTag")當(dāng)然各套API請求之間的配置也是隔離的。框架也提供了一些簡單的快捷配置方法,比如addInterceptor、addNetworkInterceptor等,更多的配置可以通過上述方式,獲取retrofitBuilder和okHttpBuilder來配置。
通過Tag的方式或許不是最好的方式,我也會繼續(xù)嘗試其他的方式,以對比便利性,如果大家有更好的方案提議,也希望能夠留言告訴我,感謝大家。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章
Android自定義控件實現(xiàn)可左右滑動的導(dǎo)航條
這篇文章主要介紹了Android自定義控件實現(xiàn)可左右滑動的導(dǎo)航條,能響應(yīng)快速滑動,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-07-07
Android Studio 2020新版本卡在Gradle downloading/sync failed/下載緩慢/
Android Studio 2020新版本 卡在Gradle downloading / sync failed / 下載緩慢 / 下載超時 親測有效解決辦法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2020-12-12
解決Android Studio突然不顯示logcat日志的問題
這篇文章主要介紹了解決Android Studio突然不顯示logcat日志的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-04-04
Android實現(xiàn)頂部導(dǎo)航欄可點擊可滑動效果(仿微信仿豆瓣網(wǎng))
這篇文章主要介紹了 Android實現(xiàn)頂部導(dǎo)航欄可點擊可滑動效果(仿微信仿豆瓣網(wǎng)),非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-03-03
Android自定義ImageView實現(xiàn)點擊兩張圖片切換效果
這篇文章主要為大家詳細(xì)介紹了Android自定義ImageView實現(xiàn)點擊兩張圖片切換效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12
Android編程之Button控件配合Toast控件用法分析
這篇文章主要介紹了Android編程之Button控件配合Toast控件用法,結(jié)合實例形式分析了Button控件及Toast控件的功能及具體使用技巧,需要的朋友可以參考下2015-12-12

