Android網(wǎng)絡(luò)封裝(從零開始教你中級(jí)篇)

概述

回顧上一篇, Android網(wǎng)絡(luò)封裝的基礎(chǔ)?我們收獲了知識(shí) - Java 網(wǎng)絡(luò)庫API非常強(qiáng)大,創(chuàng)建一個(gè)請(qǐng)求客戶端的操作竟如此簡單,核心代碼非常少。但,我們是通過兩個(gè)方法實(shí)現(xiàn)的GET與POST,并且URL,參數(shù)等等是寫死的,無法配置,不夠靈活,接下來我進(jìn)行了封裝,封裝后基本滿足一般需求。

聲明

本文使用的例子,是從無到有,從簡單到復(fù)雜,使用的是同一個(gè)。

Java例子

既然是抽離,那先看下哪些元素可以抽取


參數(shù)封裝


實(shí)際開發(fā)中,我們一般可以對(duì)HTTP涉及到的參數(shù)逐個(gè)抽取,你可以抽取的更多。

我又提取了一些可以做為公共方法


參數(shù)生成編碼后的字符串


上面的方法是把請(qǐng)求參數(shù)封裝成一個(gè)經(jīng)UTF-8編碼后的String串

1.GET請(qǐng)求時(shí)組拼到URL中

2.POST請(qǐng)求時(shí)作為輸入?yún)?shù)


根據(jù)GET/POST生成編碼后的URL

該方法是根據(jù)GET/POST生成對(duì)應(yīng)的URL

接下來看下核心的方法,該方法同時(shí)支持GET、POST請(qǐng)求


核心請(qǐng)求方法

核心方法就是封裝,抽出GET、POST共性。接下來看下如何調(diào)用


調(diào)用請(qǐng)求

可以看到GET、POST的調(diào)用現(xiàn)在非常統(tǒng)一,簡單。

請(qǐng)求結(jié)果問題

請(qǐng)求是放在子線程中的,如何把請(qǐng)求結(jié)果返回到主線程?我們可以使用回調(diào)CallBack,通知,EventBus 等等手段,我認(rèn)為最良好的是handler + 回調(diào)。事實(shí)證明多數(shù)網(wǎng)絡(luò)框架也是該方式。我們來看下結(jié)果如何傳到主線程的。

1. 聲明網(wǎng)絡(luò)Callback?

2.改造請(qǐng)求

3.改造Http 響應(yīng)處理部分

首先看聲明CallBack


CallBack聲明

注意:我們通常是把服務(wù)器返回值為HTTP_OK 即狀態(tài)碼為200 一律回調(diào)onSuccess() 方法。有人可能會(huì)問,“但是我登錄失敗了?。恳?yàn)橛脩裘艽a不正確,還是調(diào)用onSuccess()嗎?” 是的,你沒看錯(cuò),依舊調(diào)用這個(gè)。 你可以理解為,業(yè)務(wù)服務(wù)器正常工作響應(yīng),一律都是Success的。拿到響應(yīng)后,你可以與服務(wù)器約定好“業(yè)務(wù)狀態(tài)碼” 比如 0 統(tǒng)一代表請(qǐng)求成功。 比如1代表請(qǐng)求失敗。 ?在登錄接口里, 1代表用戶名錯(cuò)誤,2代表密碼錯(cuò)誤 ?3代表xxxxx ?隨意你們來定義。

講明白了,我們來看下響應(yīng)核心改造。首先是增加入?yún)ⅲ卣{(diào)



然后是核心響應(yīng)改造


我們看到改造的代碼也很簡單。根據(jù)服務(wù)器響應(yīng)狀態(tài)碼區(qū)分onSuccess和onError

來看下這個(gè)時(shí)候主線程內(nèi)的調(diào)用,如何變化的。


我們?cè)嚵艘幌拢F(xiàn)在故意響應(yīng)非200應(yīng)答。Toast處理告訴用戶

結(jié)束語

這篇文章介紹了如何抽取,如何封裝,如何從子線程把結(jié)果給主線程處理。很多網(wǎng)絡(luò)封裝的框架核心就上面的思想。還有一些功能更強(qiáng)大的拓展,比如自己創(chuàng)建隊(duì)列,設(shè)置優(yōu)先級(jí),設(shè)置請(qǐng)求Tag區(qū)別請(qǐng)求,包裝更強(qiáng)大的請(qǐng)求,比如增加上傳下載,顯示進(jìn)度條(無非是響應(yīng)時(shí)拿到字節(jié)流做回調(diào))等等。這些都是深層次的對(duì)上面核心代碼的改造。原理是一樣的!

最后編輯于
?著作權(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),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

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

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