您好,登錄后才能下訂單哦!
這篇文章主要介紹“Retrofit怎么使用”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“Retrofit怎么使用”文章能幫助大家解決問題。
文中所有 Retrofit 都是指的 Retrofit2
Retrofit其實我們可以理解為OkHttp的加強版,它也是一個網絡加載框架。 底層是使用OKHttp封裝的。準確來說,網絡請求的工作本質上是OkHttp完成,
而 Retrofit 僅負責網絡請求接口的封裝。它的一個特點是包含了特別多注解,<br>方便簡化你的代碼量。<br>優點:
超級解耦
可以配置不同HttpClient來實現網絡請求
支持同步、異步和RxJava
可以配置不同的反序列化工具來解析數據,如:json、xml
請求速度快,使用非常方便靈活
配置依賴:
implementation 'com.squareup.retrofit2:retrofit:2.5.0'//Retrofit依賴 implementation 'com.squareup.retrofit2:converter-gson:2.5.0'//可選依賴,解析json字符所用
<br>_<br>網絡權限:
<uses-permission android:name="android.permission.INTERNET" />
_<br>步驟:
定義接口類(封裝URL地址和數據請求)
實例化Retrofit
通過Retrofit實例創建接口服務對象
接口服務對象調用接口中的方法,獲取Call對象
Call對象執行請求(異步,同步請求)
Retrofit retrofit = new Retrofit.Builder() .baseUrl("http://localhost:6666") .build();
_
//baseURL(從頭開始到任意一個斜杠結束) String baseURL="https://www.wanandroid.com/article/list/0/"; @GET("json?cid=60") Call<ResponseBody> getData(); //獲取Retrofit對象 Retrofit retrofit = new Retrofit.Builder() .baseUrl(MyServer.baseURL) .build(); //通過Retrofit獲取接口服務對象 MyServer server = retrofit.create(MyServer.class); //接口對象調用其方法獲取call對象 Call<ResponseBody> data = server.getData(); //和 okhttp 使用方法差不多,不同的是 android 系統回調方法執行在主線程 //call執行請求 data.enqueue(new Callback<ResponseBody>() { @Override public void onResponse(Call<ResponseBody> call, Response<ResponseBody> response) { try { String json = response.body().string(); Log.e(TAG, "onFailure: " + response.body().string()); } catch (Exception e) { e.printStackTrace(); } } @Override public void onFailure(Call<ResponseBody> call, Throwable t) { Log.e(TAG, "onFailure: " + t.getMessage()); } });
_
String URL = "http://apicloud.mob.com/appstore/health/";//必須以反斜杠結尾 public interface MyServer { //POST("search?") POST("search")相同 //@Field("key") String value post請求用來提交參數的 //@FormUrlEncoded post請求提交form表單的時候如果有參數,需要填加這個注解,用來將提交的參數編碼 //post請求不提交參數,不要加, //如果有提交的參數,沒有加@FormUrlEncoded //@Field和@FieldMap一樣,@FieldMap只不過是把一個一個的參數,合成一個map @POST("search?") @FormUrlEncoded Call<ResponseBody> postData1(@Field("key") String appKey,@Field("name") String appKey); @POST("search") @FormUrlEncoded Call<ResponseBody> postData2(@FieldMap Map<String,Object> map); } //POST異步 private void initPostEnqueue() { //1.創建Retrofit對象 Retrofit retrofit = new Retrofit.Builder() .baseUrl(MyServer.URL) .build(); //2.獲取MyServer接口服務對象 MyServer myServer = retrofit.create(MyServer.class); //3.獲取Call對象 //方式一 Call<ResponseBody> call1 = myServer.postData1("908ca46881994ffaa6ca20b31755b675"); //方式二 //不用切換主線程了,因為Retrofit幫我們切過了 //okHttpClient需要自己切換主線程 Map<String,Object> map = new HashMap<>(); map.put("appKey","908ca46881994ffaa6ca20b31755b675"); Call<ResponseBody> call = myServer.postData2(map); //4.Call對象執行請求 call.enqueue(new Callback<ResponseBody>() { @Override public void onResponse(Call<ResponseBody> call,Response<ResponseBody> response) { try { String result = response.body().string(); Log.e("retrofit", "onResponse: "+result); tv.setText(result);//默認直接回調主線程 } catch (IOException e) { e.printStackTrace(); } } @Override public void onFailure(Call<ResponseBody> call, Throwable t) { Log.e("retrofit", "onFailure: "+t.getMessage()); } }); }
_
//get @GET("data/%E7%A6%8F%E5%88%A9/20/2") Call<GetBean> getData(); //post @POST("data/%E7%A6%8F%E5%88%A9/20/2") Call<GetBean> getData2(); //field @POST("register") @FormUrlEncoded Call<PostBean> getData3(@Field("username") String username, @Field("password") String password, @Field("phone") String phone, @Field("verify") String verify); //query @GET("project/list/1/json") Call<QueryBean> getData4(@Query("cid") int cid); //fieldMap @POST("register") @FormUrlEncoded Call<PostBean> getData5(@FieldMap Map<String, String> map); //queryMap @GET("project/list/1/json?") Call<QueryBean> getData6(@QueryMap Map<String, Object> map); //body @POST("user/login") Call<BodyBean> getData7(@Body RequestBody requestBody); //path @GET("data/%E7%A6%8F%E5%88%A9/20/{page}") Call<GetBean> getData8(@Path("page") int page); //url @GET Call<GetBean> getData9(@Url String url_query);
_
方式1:
這是單個 headers 和 多個 headers 的普通添加方式<br>方式2:<br>
代碼添加<br>方式3:
Retrofit 支持多種方式數據解析
需要在Geadle中添加依賴
Gson:implementation 'com.squareup.retrofit2:converter-gson:2.0.2' Jackson:implementation 'com.squareup.retrofit2:converter-jackson:2.0.2'
<br>對比 Okhttp
準確來說,Retrofit 是一個 RESTful 的 HTTP 網絡請求框架的封裝。
原因:網絡請求的工作本質上是 OkHttp 完成,而 Retrofit 僅負責 網絡請求接口的封裝
App應用程序通過 Retrofit 請求網絡,實際上是使用 Retrofit 接口層封裝請求參數、Header、Url 等信息,之后由 OkHttp 完成后續的請求操作
在服務端返回數據之后,OkHttp 將原始的結果交給 Retrofit,Retrofit根據用戶的需求對結果進行解析
因為他的下層是 okhttp, 所以 hook okhttp 那一套一樣的可以 hook Retrofit
關于“Retrofit怎么使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。