OkHttp 4.x出來已經(jīng)有一段時間了衬潦,根據(jù)JCenter的上傳記錄,早在今年五月份,square就上傳了4.X的第一個版本中捆,4.0.0-alpha01。
主要的區(qū)別在于之前是基于JAVA坊饶,而4.X往后泄伪,都將會是用kotlin來寫∧浼叮可以看得出來蟋滴,kotlin將會是大勢所趨。Google了一下痘绎,發(fā)現(xiàn)還沒人寫關(guān)于OkHttp4的教程津函。其實(shí)我個人也感覺沒什么必要。這次的升級還是很平滑孤页,甚至為了和3.X兼容尔苦,包名都仍然保持了okhttp3。但我在使用過程中行施,還是發(fā)現(xiàn)了一些不同允坚,所以稍微做一下小結(jié),方便使用的人們理解蛾号。
官網(wǎng)上對這次升級做了一些說明稠项,大致翻譯一下,語言由java改為kotlin鲜结,包名保持不變展运,通過 japicmp實(shí)現(xiàn)二進(jìn)制兼容,在不更改.kt和.java文件的基礎(chǔ)上精刷,從3.x遷移到4.X乐疆。還有一些之前不是final的方法現(xiàn)在改成final了。之前的getter和setter也在kotlin里用不到了,balabala等等贬养。以前三條為例子,他說使用了japicmp琴庵,而japicmp是一個可以比較兩個jar包不同的library误算,然后再看一下4.X的源碼你會發(fā)現(xiàn),為了兼容3.x迷殿,square還是花了很多心血的儿礼,比如大量的@JvmName。
剩下的也差不多庆寺。
看起來好像4.X和3.X在使用上完全沒有區(qū)別蚊夫,但并非如此。這里懦尝,我以post提交為例子知纷,說明一下不同點(diǎn)
目前在官網(wǎng)上在提交post的請求的時候壤圃,任然會告訴你這么寫。
現(xiàn)在你想著琅轧,我會okhttp3.X伍绳,也會kotlin,那么只要把原來的java代碼改成kotlin就行了乍桂。然而改完運(yùn)行卻是這樣的
這樣的代碼在java里是完全沒問題冲杀,但在kotlin里,卻無法通過編譯睹酌。這可能就是square在不改動原有.java文件的基礎(chǔ)上遷移到okhttp 4.x吧权谁。如果你在.kt文件里用的是3.x版本,那么是完全沒問題的憋沿。
解決錯誤也很簡單旺芽,查看kotlin源碼可以得知,現(xiàn)在這個方法被標(biāo)記為過時方法卤妒,我們要使用kotlin里的擴(kuò)展方法甥绿,也即是這么寫:
import okhttp3.MediaType.Companion.toMediaType
import okhttp3.RequestBody.Companion.toRequestBody
fun post(){
val okHttpClient=OkHttpClient()
val jsonObject=JSONObject()
jsonObject.put("abc","bcd")
val requestBody=jsonObject.toString().toRequestBody("application/json; charset=utf-8".toMediaType())
val request=Request.Builder().url("https://www.baidu.com").post(requestBody).build()
okHttpClient.newCall(request).enqueue(object :Callback{
override fun onFailure(call: Call, e: IOException) {
}
override fun onResponse(call: Call, response: Response) {
Log.d("onResponse","kt example:"+response.body?.string())
}
})
}
注意這里有個細(xì)節(jié),我們必須手動導(dǎo)入okhttp的局部擴(kuò)展方法则披,否是是沒有辦法把string轉(zhuǎn)為requestbody的
如果你用的是java共缕,但想用Okhttp4的話,則那個內(nèi)部的擴(kuò)展方法變成了這樣
擴(kuò)展方法本質(zhì)就是增加一個自身的參數(shù)士复,所以當(dāng)我們用java調(diào)用的時候图谷,會看到一個$開頭的參數(shù),這個就是原來kotlin里的擴(kuò)展方法
GET的話和原來一模一樣阱洪,沒什么改變便贵,就不提了。
最后冗荸,我基于okhttp4承璃,寫了一個網(wǎng)絡(luò)請求庫,oksimple蚌本,歡迎使用和提意見