android實現(xiàn)okHttp的get和post請求的簡單封裝與使用
由于Android課程項目需要,特地查閱了okHttp的使用,發(fā)現(xiàn)網(wǎng)上找的大多和自己的需求不一樣。所以就著團隊項目需要,自己簡單封裝了一個okHttp的get和post請求。
話不多說,直接看代碼吧!
一、前期需要用到的屬性封裝
private static Request request = null; private static Call call = null; private static int TimeOut = 120; //單例獲取ohttp3對象 private static OkHttpClient client = null; /** * OkHttpClient的構(gòu)造方法,通過線程鎖的方式構(gòu)造 * @return OkHttpClient對象 */ private static synchronized OkHttpClient getInstance() { if (client == null) { client = new OkHttpClient.Builder() .readTimeout(TimeOut, TimeUnit.SECONDS) .connectTimeout(TimeOut, TimeUnit.SECONDS) .writeTimeout(TimeOut, TimeUnit.SECONDS) .build(); } return client; } /** * callback接口 * 異步請求時使用 */ static class MyCallBack implements Callback { private OkHttpCallback okHttpCallBack; public MyCallBack(OkHttpCallback okHttpCallBack) { this.okHttpCallBack = okHttpCallBack; } @Override public void onFailure(Call call, IOException e) { okHttpCallBack.onFailure(e); } @Override public void onResponse(Call call, Response response) throws IOException { okHttpCallBack.onSuccess(response); } } /** * 獲得同步get請求對象Response * @param url * @return Response */ private static Response doSyncGet(String url) { //創(chuàng)建OkHttpClient對象 client = getInstance(); request = new Request.Builder() .url(url)//請求鏈接 .build();//創(chuàng)建Request對象 try { //獲取Response對象 Response response = client.newCall(request).execute(); return response; } catch (IOException e) { e.printStackTrace(); return null; } } /** * 獲得異步get請求對象 * @param url 請求地址 * @param callback 實現(xiàn)callback接口 */ private static void doAsyncGet(String url,OkHttpCallback callback) { MyCallBack myCallback = new MyCallBack(callback); client = getInstance(); request = new Request.Builder() .url(url) .get() .build(); client.newCall(request).enqueue(myCallback); }
其中,OKHttpCallback接口為:
import java.io.IOException; import okhttp3.Response; public interface OkHttpCallback { void onFailure(IOException e); void onSuccess(Response response); }
二、get請求封裝
1.項目需求是全程使用json格式的字符串進行交互,所以以下是針對json來封裝的。
2.在這里說明一下,返回的是字符串類型,表示后臺返回的json字符串,另外,為什么要用list來定義返回值result,result.get(0)為return值,因為直接用String來定義result會報錯,具體原因未知。。。。
(1)同步get請求
/** * 同步get請求 * 例如:請求的最終地址為:http://127.0.0.1:8081/user/getUser/123 * @param url 基本請求地址 例子: http://127.0.0.1:8081 * @param args 請求的參數(shù) args[]=new String[]{"user","getUser","123"} * @return String */ public static String getSyncRequest(String url,String... args) { List<String> result=new ArrayList<>();//返回值 String address=url; for(int i=0;i<args.length;i++){ address=address+"/"+args[i]; } final String finalAddress = address; new Thread(new Runnable() { @Override public void run() { Response finalResponse = doSyncGet(finalAddress); String res = null; try { Log.d("同步get請求請求地址:",finalAddress); if (finalResponse.isSuccessful()) {//請求成功 ResponseBody body = finalResponse.body();//拿到響應(yīng)體 res = body.string(); result.add(res); Log.d("HttpUtil", "同步get請求成功!"); Log.d("請求對象:", res); } else { Log.d("HttpUtil", "同步get請求失??!"); } } catch (IOException e) { e.printStackTrace(); } } }).start(); /**因為函數(shù)返回是立刻執(zhí)行的,而result要在請求完成之后才能獲得 * 所以需要等待result獲得返回值之后再執(zhí)行return*/ while(result.size()==0){ try { TimeUnit.MILLISECONDS.sleep(10);//等待xx毫秒 } catch (InterruptedException e) { e.printStackTrace(); } } return result.get(0); }
(2)異步get請求
/** * 異步get請求 * 例如:請求的最終地址為:http://127.0.0.1:8081/user/getUser/123 * @param url 基本請求地址 例子: http://127.0.0.1:8081 * @param args 請求的參數(shù) args[]=new String[]{"user","getUser","123"} * @return String */ public static String getAsyncRequest(String url,String... args){ List<String> result=new ArrayList<>(); String address=url; for(int i=0;i<args.length;i++){ address=address+"/"+args[i]; } final String finalAddress = address; doAsyncGet(finalAddress, new OkHttpCallback() { @Override public void onFailure(IOException e) { Log.d("異步get請求地址:",finalAddress); Log.d("HttpUtil", "異步get請求失??!"); } @Override public void onSuccess(Response response) { Log.d("異步get請求地址:",finalAddress); String res = null; try { res = response.body().string(); } catch (IOException e) { e.printStackTrace(); } result.add(res); Log.d("HttpUtil", "異步get請求成功!"); Log.d("請求對象:", res); } }); /**因為函數(shù)返回是立刻執(zhí)行的,而result要在請求完成之后才能獲得 * 所以需要等待result獲得返回值之后再執(zhí)行return*/ while(result.size()==0){ try { TimeUnit.MILLISECONDS.sleep(10);//等待xx毫秒 } catch (InterruptedException e) { e.printStackTrace(); } } return result.get(0); }
三、post請求
在此說明一下,后端接收的是一個name為“json”的字符串,實際就是傳了個json字符串作為請求表單中的數(shù)據(jù),后端通過解析這個json字符串進行下一步的操作
(1)同步post請求
/** * 同步post請求 * 例如:請求的最終地址為:http://127.0.0.1:8081/user/getUser/123 * @param url 基本請求地址 例子: http://127.0.0.1:8081 * @param json 提交的json字符串 * @param args 請求的參數(shù) args[]=new String[]{"user","getUser","123"} * @return */ public static String postSyncRequest(String url,String json,String... args){ List<String> result=new ArrayList<>(); String address=url; for(int i=0;i<args.length;i++){ address=address+"/"+args[i]; } final String finalAddress = address; new Thread(new Runnable() { @Override public void run() { client=getInstance(); Log.d("同步post請求地址:",finalAddress); FormBody.Builder formBody = new FormBody.Builder(); formBody.add("json",json); request=new Request.Builder() .url(finalAddress) .post(formBody.build()) .addHeader("device-platform", "android") .build(); try{ Response response=client.newCall(request).execute(); String res=response.body().string(); result.add(res); Log.d("HttpUtil", "同步post請求成功!"); Log.d("請求對象:", res); }catch (Exception e){ Log.d("HttpUtil", "同步post請求失敗!"); e.printStackTrace(); } } }).start(); /**因為函數(shù)返回是立刻執(zhí)行的,而result要在請求完成之后才能獲得 * 所以需要等待result獲得返回值之后再執(zhí)行return*/ while(result.size()==0){ try { TimeUnit.MILLISECONDS.sleep(10);//等待xx毫秒 } catch (InterruptedException e) { e.printStackTrace(); } } return result.get(0); }
(2)異步post請求
/** * 異步post請求 * 例如:請求的最終地址為:http://127.0.0.1:8081/user/getUser/123 * @param url 基本請求地址 例子: http://127.0.0.1:8081 * @param json 提交的json字符串 * @param args 請求的參數(shù) args[]=new String[]{"user","getUser","123"} * @return */ public static String postAsyncRequest(String url,String json,String... args){ List<String> result=new ArrayList<>(); String address=url; for(int i=0;i<args.length;i++){ address=address+"/"+args[i]; } final String finalAddress = address; Log.d("同步post請求地址:",finalAddress); client=getInstance(); FormBody.Builder formBody = new FormBody.Builder();//創(chuàng)建表單請求體 formBody.add("json",json); request = new Request.Builder() .url(finalAddress) .post(formBody.build()) .addHeader("device-platform", "android") .build(); Call call=client.newCall(request); call.enqueue(new Callback() { @Override public void onFailure(@NotNull Call call, @NotNull IOException e) { new Thread(new Runnable() { @Override public void run() { Log.d("HttpUtil","異步post請求失??!"); } }).start(); } @Override public void onResponse(@NotNull Call call, @NotNull Response response) throws IOException { new Thread(new Runnable() { @Override public void run() { String res = null; try { res = response.body().string(); } catch (IOException e) { e.printStackTrace(); } result.add(res); Log.d("HttpUtil","異步post請求成功!"); Log.d("請求對象",res); } }).start(); } }); /**因為函數(shù)返回是立刻執(zhí)行的,而result要在請求完成之后才能獲得 * 所以需要等待result獲得返回值之后再執(zhí)行return*/ while(result.size()==0){ try { TimeUnit.MILLISECONDS.sleep(10);//等待xx毫秒 } catch (InterruptedException e) { e.printStackTrace(); } } return result.get(0); }
四、依賴以及相關(guān)說明
相關(guān)依賴為:(okHttp和Gson)
implementation 'com.squareup.okhttp3:okhttp:4.2.2' implementation 'com.google.code.gson:gson:2.7'
由于取消掉延時會導(dǎo)致result還沒有被賦值就已經(jīng)進行到return這里了,所以在每個請求方法中在return之前都加了個延時,直到result被賦值了再執(zhí)行return
下一篇是講android是如何通過okHttp跟后端交互起來的,以及相關(guān)例子。
到此這篇關(guān)于android實現(xiàn)okHttp的get和post請求的簡單封裝與使用的文章就介紹到這了,更多相關(guān)android okHttp的get和post請求內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android開發(fā)中TextView各種常見使用方法小結(jié)
這篇文章主要介紹了Android開發(fā)中TextView各種常見使用方法,結(jié)合實例形式總結(jié)分析了Android開發(fā)中TextView各種常見布局與功能實現(xiàn)技巧,需要的朋友可以參考下2019-04-04詳解Android使用CoordinatorLayout+AppBarLayout實現(xiàn)拉伸頂部圖片功能
這篇文章主要介紹了Android使用CoordinatorLayout+AppBarLayout實現(xiàn)拉伸頂部圖片功能,本文實例文字相結(jié)合給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-10-10Android RecyclerView仿新聞頭條的頻道管理功能
這篇文章主要介紹了Android RecyclerView仿新聞頭條的頻道管理功能,需要的朋友可以參考下2017-06-06Android自定義對話框Dialog的簡單實現(xiàn)
這篇文章主要為大家詳細(xì)介紹了Android自定義對話框Dialog的簡單實現(xiàn),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-08-08Android JNI 調(diào)用時緩存字段和方法ID示例
這篇文章主要介紹了Android JNI 調(diào)用時緩存字段和方法ID示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-07-07Android中EditText實現(xiàn)不可編輯解決辦法
這篇文章主要介紹了Android中EditText實現(xiàn)不可編輯解決辦法,需要的朋友可以參考下2014-12-12Android的HTTP類庫Volley入門學(xué)習(xí)教程
這篇文章主要介紹了Android應(yīng)用開發(fā)框架Volley的入門學(xué)習(xí)教程,Volley適合于輕量級的通信功能開發(fā),善于處理JSON對象,需要的朋友可以參考下2016-02-02