android Retrofit2網(wǎng)絡(luò)請求封裝介紹
1. Retrofit使用
Retrofit是一個現(xiàn)在網(wǎng)絡(luò)請求框架,先來說一下怎么使用
網(wǎng)絡(luò)權(quán)限(添加到AndroidManifest.xml)
<uses-permission android:name="android.permission.INTERNET" />
gradle依賴(添加到build.gradle)
implementation("com.squareup.okhttp3:okhttp:4.9.2")
implementation 'com.squareup.retrofit2:retrofit:2.9.0'
implementation 'com.squareup.retrofit2:converter-gson:2.9.0'
implementation 'com.squareup.retrofit2:converter-scalars:2.9.0'
定義接口,網(wǎng)絡(luò)請求的方法
public interface Request {
@GET("/xx/xx")
Call<ResponseBody> get();
}
實(shí)例化Retrofit
Retrofit retrofit = new Retrofit.Builder().baseUrl("BASE_URL").build();
通過Retrofit實(shí)例創(chuàng)建接口服務(wù)對象
Request request = retrofit.create(Request.class);
調(diào)用接口中的方法
Call<ResponseBody> call = request.get();
執(zhí)行異步請求(同步請求需要創(chuàng)建一個新的線程去執(zhí)行)
call.enqueue(new retrofit2.Callback<ResponseBody>() {
@Override
public void onResponse(retrofit2.Call<ResponseBody> call, retrofit2.Response<ResponseBody> response) {
}
@Override
public void onFailure(retrofit2.Call<ResponseBody> call, Throwable t) {
}
});
2. Retrofit封裝
以上可以看出Retrofit是個好東西,可是用起來是比較麻煩的,所有在實(shí)際使用中對Retrofit進(jìn)行一下小小的封裝是很有必要的。
定義接口(所有的請求參數(shù)都是以map的形式)
public interface Request {
/**
* 不帶參數(shù)的get請求
* @param url
* @return
*/
@GET()
Call<ResponseBody> get(@Url String url);
/**
* 帶參數(shù)的get請求
* @param url
* @param map 參數(shù)默認(rèn)是map
* @return
*/
@GET()
Call<ResponseBody> get(@Url String url, @QueryMap Map<String,String> map);
/**
* 不帶參數(shù)的post請求
* @param url
* @return
*/
@POST()
Call<ResponseBody> post(@Url String url);
/**
* 帶參數(shù)的post請求
* @param url
* @param map
* @return
*/
@POST()
@FormUrlEncoded
Call<ResponseBody> post(@Url String url, @FieldMap Map<String,String> map);
}
定義RetrofitManager,以單例模式獲取Retrofit實(shí)例
public enum RetrofitManager {
/**
* RetrofitManager的實(shí)例
*/
INSTANCE;
/**
*
* 后端接口的baseUrl,且只考慮一個url的情況(ip+端口,或者域名)
*/
private static final String BASE_URL = " Your BASE_URL";
private Retrofit retrofit;
/**
* 返回Retrofit實(shí)例,不添加轉(zhuǎn)換器
* @return
*/
public Retrofit getRetrofit(){
if(retrofit == null){
retrofit = new Retrofit.Builder()
.baseUrl(BASE_URL)
.build();
}
return retrofit;
}
}
自定義的RetrofitCallback,在發(fā)送請求時,通過匿名對象作為參數(shù)獲取后端的響應(yīng)結(jié)果。
public abstract class RetrofitCallback {
/**
* 開始執(zhí)行的方法
*/
public void onStart(){
//開啟loading
}
/**
* 結(jié)束執(zhí)行的方法
*/
public void onCompleted(){
//關(guān)閉loading
}
/**
* 執(zhí)行成功
* @param resultJsonString 返回的json字符串
*/
public abstract void onSuccess(String resultJsonString);
/**
* 失敗
* @param t 異常
*/
public abstract void onError(Throwable t);
/**
* 提示:服務(wù)異常
*/
public void serverErrMsg(){
//xxx
}
/**
* 提示:請求失敗
*/
public void reqErrMsg(){
//xxx
}
/**
* 提示:成功
*/
public void okMsg(){
//xxx
}
}
定義RetrofitUtil,封裝get和post方法。將RetrofitCallback作為請求參數(shù),在發(fā)送請求時重寫onSuccess和onError方法,執(zhí)行具體的操作。
public class RetrofitUtil {
private Retrofit(){}
/**
* 無參的get請求
* @param url
* @param callback
*/
public static void get(String url, RetrofitCallback callback){
sendRequest(getRequest().get(url),callback);
}
/**
* 有參的get請求
* @param url 請求的url
* @param map 參數(shù)
* @param callback 請求結(jié)束的回調(diào)
*/
public static void get(String url, Map<String,String> map, RetrofitCallback callback){
sendRequest(getRequest().get(url,map),callback);
}
/**
* 無參的post請求
* @param url
* @param callback
*/
public static void post(String url, RetrofitCallback callback){
sendRequest(getRequest().post(url), callback);
}
/**
* 有參的post請求
* @param url
* @param map
* @param callback
*/
public static void post(String url, Map<String,String> map, RetrofitCallback callback){
sendRequest(getRequest().post(url,map), callback);
}
/**
* 獲取Request實(shí)例
* @return
*/
private static Request getRequest(){
Retrofit retrofit = RetrofitManager.INSTANCE.getRetrofit();
return retrofit.create(Request.class);
}
/**
* 發(fā)送請求的共通方法,并對響應(yīng)結(jié)果進(jìn)行處理
* @param call
* @param callback 自定義的Callback
*/
private void sendRequest(Call<ResponseBody> call,RetrofitCallback callback){
//開啟loading
callback.onStart();
//異步請求
call.enqueue(new Callback<ResponseBody>() {
@Override
public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) {
//關(guān)閉loading
callback.onCompleted();
if(response.isSuccessful()){
//執(zhí)行RetrofitCallback的onSuccess方法,獲取響應(yīng)結(jié)果的json字符串
try {
String result = response.body().string();
callback.onSuccess(result);
//響應(yīng)成功
if(StringUtils.equals(result, Constant.SUCCESS)){
callback.okMsg();
}
} catch (IOException e) {
e.printStackTrace();
}
}else{
//服務(wù)異常
callback.serverErrMsg();
}
}
@Override
public void onFailure(Call<ResponseBody> call, Throwable t) {
callback.onCompleted();
//請求失敗
callback.onError(t);
callback.reqErrMsg();
}
}
});
}
}
3. RetrofitUtil使用
get無參請求
RetrofitUtil.get("/xx/xx", new RetrofitCallback() {
@Override
public void onSuccess(String resultJsonString) {
}
@Override
public void onError(Throwable t) {
}
});
get有參請求
Map<String,String> map = new HashMap<>(16);
map.put("key","value");
//xxx
RetrofitUtil.get("/xx/xx", map,new RetrofitCallback() {
@Override
public void onSuccess(String resultJsonString) {
xxxx
}
@Override
public void onError(Throwable t) {
xxxx
}
});
post請求和get的使用方法相似
最后
本次只對get和post進(jìn)行了封裝,項(xiàng)目中只用到了這些就沒有對文件上傳下載以及別的請求方式進(jìn)行封裝。且沒有添加轉(zhuǎn)換器,可在RetrofitManager的getRetrofit()方法中自行添加。大概的封裝思路就是這樣的,可以自行發(fā)揮。
此文也只是在記錄項(xiàng)目中對Retrofit的使用,對Retrofit的原理并沒有較深的了解。
到此這篇關(guān)于android Retrofit2網(wǎng)絡(luò)請求封裝介紹的文章就介紹到這了,更多相關(guān)android Retrofit2網(wǎng)絡(luò)封裝內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android短信驗(yàn)證碼(用的Mob短信驗(yàn)證)
這篇文章主要為大家詳細(xì)介紹了Android短信驗(yàn)證碼,使用Mob短信驗(yàn)證,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05
Android 利用ViewPager實(shí)現(xiàn)圖片可以左右循環(huán)滑動效果附代碼下載
本文通過一個小demo給大家展示一段代碼實(shí)現(xiàn)viewpage圖片左右循環(huán)滑動效果,對viewgager循環(huán)滑動相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧2015-11-11
自己實(shí)現(xiàn)的android樹控件treeview
在項(xiàng)目中經(jīng)常需要一個需要一個樹狀框架,因?yàn)橐恍┰驔]有使用系統(tǒng)自帶的控件,所以就自己寫了一個,現(xiàn)在分享給大家2014-01-01
android開發(fā)仿ios的UIScrollView實(shí)例代碼
下面小編就為大家分享一篇android開發(fā)仿ios的UIScrollView實(shí)例代碼,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01
android實(shí)現(xiàn)多點(diǎn)觸摸應(yīng)用
這篇文章主要為大家詳細(xì)介紹了android實(shí)現(xiàn)多點(diǎn)觸摸應(yīng)用,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
RecyclerView仿應(yīng)用列表實(shí)現(xiàn)網(wǎng)格布局
這篇文章主要為大家詳細(xì)介紹了RecyclerView仿應(yīng)用列表實(shí)現(xiàn)網(wǎng)格布局,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-09-09
Android中AndroidStudio&Kotlin安裝到運(yùn)行過程及常見問題匯總
這篇文章主要介紹了Android(AndroidStudio&Kotlin)安裝到運(yùn)行過程及常見問題匯總,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒借鑒價(jià)值,需要的朋友可以參考下2020-03-03

