android實(shí)現(xiàn)okHttp的get和post請求的簡單封裝與使用
由于Android課程項(xiàng)目需要,特地查閱了okHttp的使用,發(fā)現(xiàn)網(wǎng)上找的大多和自己的需求不一樣。所以就著團(tuán)隊(duì)項(xiàng)目需要,自己簡單封裝了一個(gè)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接口 * 異步請求時(shí)使用 */ static class MyCallBack implements Callback {private OkHttpCallback okHttpCallBack;public MyCallBack(OkHttpCallback okHttpCallBack) { this.okHttpCallBack = okHttpCallBack;}@Overridepublic void onFailure(Call call, IOException e) { okHttpCallBack.onFailure(e);}@Overridepublic 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 實(shí)現(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.項(xiàng)目需求是全程使用json格式的字符串進(jìn)行交互,所以以下是針對json來封裝的。2.在這里說明一下,返回的是字符串類型,表示后臺返回的json字符串,另外,為什么要用list來定義返回值result,result.get(0)為return值,因?yàn)橹苯佑肧tring來定義result會報(bào)錯,具體原因未知。。。。
(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();/**因?yàn)楹瘮?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); }});/**因?yàn)楹瘮?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請求
在此說明一下,后端接收的是一個(gè)name為“json”的字符串,實(shí)際就是傳了個(gè)json字符串作為請求表單中的數(shù)據(jù),后端通過解析這個(gè)json字符串進(jìn)行下一步的操作
(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();/**因?yàn)楹瘮?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(); }});/**因?yàn)楹瘮?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’
由于取消掉延時(shí)會導(dǎo)致result還沒有被賦值就已經(jīng)進(jìn)行到return這里了,所以在每個(gè)請求方法中在return之前都加了個(gè)延時(shí),直到result被賦值了再執(zhí)行return
下一篇是講android是如何通過okHttp跟后端交互起來的,以及相關(guān)例子。
到此這篇關(guān)于android實(shí)現(xiàn)okHttp的get和post請求的簡單封裝與使用的文章就介紹到這了,更多相關(guān)android okHttp的get和post請求內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. XML在語音合成中的應(yīng)用2. 不要在HTML中濫用div3. jscript與vbscript 操作XML元素屬性的代碼4. XML入門的常見問題(三)5. ASP將數(shù)字轉(zhuǎn)中文數(shù)字(大寫金額)的函數(shù)6. .NET Framework各版本(.NET2.0 3.0 3.5 4.0)區(qū)別7. HTML5實(shí)戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)8. 基于PHP做個(gè)圖片防盜鏈9. ASP基礎(chǔ)入門第四篇(腳本變量、函數(shù)、過程和條件語句)10. php使用正則驗(yàn)證密碼字段的復(fù)雜強(qiáng)度原理詳細(xì)講解 原創(chuàng)
