Android Retrofit框架的使用
Retrofit介紹
Retrofit是Square開(kāi)源的一款基于OkHttp(也是他家的)封裝的網(wǎng)絡(luò)請(qǐng)求框架,主要的網(wǎng)絡(luò)請(qǐng)求還是OkHttp來(lái)完成,Retrofit只是對(duì)OkHttp進(jìn)行了封裝,可以讓我們更加簡(jiǎn)單方便的使用,目前大部分公司都在使用這款框架,Retrofit的原理也是面試必問(wèn)的問(wèn)題之一了,所以我們不僅要會(huì)使用,也要對(duì)其實(shí)現(xiàn)原理有一個(gè)大概的了解。
本片文章從使用角度來(lái)說(shuō),不對(duì)的地方希望大家在評(píng)論區(qū)交流,我會(huì)及時(shí)改進(jìn),共同進(jìn)步,文章中的demo可以從github下載。
Retrofit優(yōu)點(diǎn)
Retrofit的大部分配置是通過(guò)注解來(lái)實(shí)現(xiàn)的,配置簡(jiǎn)單,使用方便;支持多種返回類(lèi)型包括RxJava和協(xié)程,可以配置不同的解析器來(lái)進(jìn)行數(shù)據(jù)解析,如Json,xml等
Retrofit的使用
以下代碼全部為Kotlin語(yǔ)言編寫(xiě),畢竟現(xiàn)在Kotlin也是大勢(shì)所趨了。
1.引入依賴(lài)項(xiàng)
github地址:github.com/square/retr…
implementation 'com.squareup.retrofit2:retrofit:2.9.0' //支持Gson解析json數(shù)據(jù) implementation 'com.squareup.retrofit2:converter-gson:2.9.0' //支持RxJava返回類(lèi)型 implementation "com.squareup.retrofit2:adapter-rxjava2:2.9.0" implementation "io.reactivex.rxjava2:rxandroid:2.0.2" //支持協(xié)程,Retrofit2.6.0及以上版本不需要引入,Retrofit內(nèi)置已經(jīng)支持 //implementation 'com.jakewharton.retrofit:retrofit2-kotlin-coroutines-adapter:0.9.2'
2.添加網(wǎng)絡(luò)權(quán)限
<uses-permission android:name="android.permission.INTERNET"/>
3.編寫(xiě)Retrofit輔助類(lèi)
首先定義一個(gè)RetrofitHelper輔助類(lèi),編寫(xiě)Retrofit單例,Retrofit內(nèi)部已經(jīng)維護(hù)了線(xiàn)程池做網(wǎng)絡(luò)請(qǐng)求,不需要?jiǎng)?chuàng)建多個(gè)
注:BASE_URL必須為 "/" 結(jié)尾
object RetrofitHelper { //baseUrl根據(jù)自己項(xiàng)目修改 private const val BASE_URL = "https://www.baidu.com" private var retrofit: Retrofit? = null private var retrofitBuilder: Retrofit.Builder? = null //Retrofit初始化 fun init(){ if (retrofitBuilder == null) { val client = OkHttpClient.Builder() .connectTimeout(20, TimeUnit.SECONDS) .readTimeout(20, TimeUnit.SECONDS) .writeTimeout(20, TimeUnit.SECONDS) .build() retrofitBuilder = Retrofit.Builder() .baseUrl(BASE_URL) //支持Json數(shù)據(jù)解析 .addConverterFactory(GsonConverterFactory.create()) //支持RxJava返回類(lèi)型 .addCallAdapterFactory(RxJava2CallAdapterFactory.create()) .client(client) } retrofit = retrofitBuilder!!.build() } fun getRetrofit():Retrofit{ if (retrofit == null) { throw IllegalAccessException("Retrofit is not initialized!") } return retrofit!! } }
然后再Application中進(jìn)行初始化
class App:Application() { override fun onCreate() { super.onCreate() RetrofitHelper.init() } }
在Manifest文件中指定Application
<application android:name=".App" android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:roundIcon="@mipmap/ic_launcher_round" android:supportsRtl="true" android:networkSecurityConfig="@xml/network_security_config" android:theme="@style/Theme.RetrofitDemo"> <activity android:name=".MainActivity"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> </application>
Android P系統(tǒng)限制了明文流量的網(wǎng)絡(luò)請(qǐng)求 解決的辦法有2種 1.把所有的http請(qǐng)求全部改為https請(qǐng)求 2.在res的xml目錄(),然后創(chuàng)建一個(gè)名為:network_security_config.xml文件
<?xml version="1.0" encoding="utf-8"?> <network-security-config> <base-config cleartextTrafficPermitted="true" /> </network-security-config>
4.定義ApiService
首先我們先用一個(gè)最簡(jiǎn)單的GET請(qǐng)求來(lái)試一下,這個(gè)接口是請(qǐng)求天氣情況的,免費(fèi)的
interface Api { @GET("http://www.weather.com.cn/data/sk/{cityCode}.html") fun getWeather(@Path("cityCode")code:String):Observable<WeatherInfo> }
定義返回類(lèi)型,為了方便打印,用的data class 類(lèi)型
data class WeatherInfo( var weatherinfo:Info?=null) { data class Info( var city:String?, var cityid:String?, var temp:String?, var WD:String?, var WS:String?, var SD:String?, var AP:String?, var njd:String?, var WSE:String?, var time:String?) }
首先用@GET注解表示該借口為get請(qǐng)求,GET注解的value為請(qǐng)求地址,完整的請(qǐng)求地址為baseUrl+value,如value為完整地址,則會(huì)使用value為請(qǐng)求地址,一般通用情況下baseUrl = "www.weather.com.cn/", 然后GET("data/sk/{cityCode}.html") @Path是網(wǎng)址中的參數(shù),用來(lái)替換。
5.實(shí)現(xiàn)接口方法
5.1RxJava方法實(shí)現(xiàn)
class RetrofitViewModel:ViewModel() { private val disposables:CompositeDisposable by lazy { CompositeDisposable() } fun addDisposable(d:Disposable){ disposables.add(d) } val weatherLiveData = MutableLiveData<WeatherInfo>() fun getWeather(){ RetrofitHelper.getRetrofit().create(Api::class.java).getWeather("101010100") .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .subscribe(object :Observer<WeatherInfo>{ override fun onComplete() {} override fun onSubscribe(d: Disposable) { addDisposable(d) } override fun onNext(t: WeatherInfo) { weatherLiveData.value = t } override fun onError(e: Throwable) { } }) } override fun onCleared() { super.onCleared() disposables.clear() } }
這里是用ViewModel中做的操作,如果是MVP模式放在Presenter中進(jìn)行就好,首先通過(guò)Retrofit單例調(diào)用Service的對(duì)象的getWeather方法,指定上下游事件的線(xiàn)程,創(chuàng)建觀(guān)察者對(duì)象進(jìn)行監(jiān)聽(tīng),在onNext方法中拿到返回結(jié)果后回調(diào)給Activity,數(shù)據(jù)回調(diào)用的是LiveData,在Activity中操作如下
class MainActivity : AppCompatActivity() { private val viewModel by viewModels<RetrofitViewModel>() private var btnWeather: Button? = null private var tvWeather: TextView? = null override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) viewModel.weatherLiveData.observe(this, Observer { tvWeather?.text = it.toString()) }) btnWeather = findViewById<Button>(R.id.btnWeather) tvWeather = findViewById(R.id.tvWeather) btnWeather?.setOnClickListener { viewModel.getWeather() } } }
在Activity中
1.創(chuàng)建ViewModel對(duì)象
2.注冊(cè)LiveData的回調(diào)
3.獲取天氣情況
如下圖所示
github地址:github.com/ZhiLiangT/R…
以上就是Android Retrofit框架的使用的詳細(xì)內(nèi)容,更多關(guān)于Android Retrofit框架的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
TextView使用SpannableString設(shè)置復(fù)合文本 SpannableString實(shí)現(xiàn)TextView的鏈接
這篇文章主要為大家詳細(xì)介紹了如何利用SpannableString實(shí)現(xiàn)TextView的鏈接效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08Android實(shí)戰(zhàn)教程第五篇之一鍵鎖屏應(yīng)用
這篇文章主要為大家詳細(xì)介紹了Android實(shí)戰(zhàn)教程第五篇之一鍵鎖屏應(yīng)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-11-11Android Studio使用USB真機(jī)調(diào)試詳解
這篇文章主要為大家詳細(xì)介紹了Android Studio使用USB真機(jī)調(diào)試的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05Flutter Http分塊下載與斷點(diǎn)續(xù)傳的實(shí)現(xiàn)
這篇文章主要介紹了Flutter Http分塊下載與斷點(diǎn)續(xù)傳的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03Android開(kāi)發(fā)之使用SQLite存儲(chǔ)數(shù)據(jù)的方法分析
這篇文章主要介紹了Android開(kāi)發(fā)之使用SQLite存儲(chǔ)數(shù)據(jù)的方法,結(jié)合實(shí)例形式分析了Android使用SQLite數(shù)據(jù)庫(kù)實(shí)現(xiàn)針對(duì)數(shù)據(jù)的增刪改查操作相關(guān)技巧,需要的朋友可以參考下2017-07-07Android Studio綁定下拉框數(shù)據(jù)詳解
這篇文章主要為大家詳細(xì)介紹了Android Studio綁定下拉框數(shù)據(jù),Android Studio綁定網(wǎng)絡(luò)JSON數(shù)據(jù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-10-10Android Studio EditText點(diǎn)擊圖標(biāo)清除文本內(nèi)容的實(shí)例解析
這篇文章主要介紹了Android Studio EditText點(diǎn)擊圖標(biāo)清除文本內(nèi)容的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11Android自定義view實(shí)現(xiàn)太極效果實(shí)例代碼
這篇文章主要介紹了Android自定義view實(shí)現(xiàn)太極效果實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-05-05Android?無(wú)障礙服務(wù)?performAction?調(diào)用過(guò)程分析
這篇文章主要介紹了Android?無(wú)障礙服務(wù)?performAction?調(diào)用過(guò)程分析,無(wú)障礙服務(wù)可以模擬一些用戶(hù)操作,無(wú)障礙可以處理的對(duì)象,通過(guò)類(lèi)?AccessibilityNodeInfo?表示,通過(guò)無(wú)障礙服務(wù),可以通過(guò)它的performAction方法來(lái)觸發(fā)一些action2022-06-06