短視頻、直播數據實時採集接口,請查看文檔: TiToDataandroid
免責聲明:本文檔僅供學習與參考,請勿用於非法用途!不然一切後果自負。json
文中全部 Retrofit 都是指的 Retrofit2api
Retrofit其實咱們能夠理解爲OkHttp的增強版,它也是一個網絡加載框架。
底層是使用OKHttp封裝的。準確來講,網絡請求的工做本質上是OkHttp完成,網絡
而 Retrofit 僅負責網絡請求接口的封裝。它的一個特色是包含了特別多註解,
方便簡化你的代碼量。
優勢:app
配置依賴:框架
implementation 'com.squareup.retrofit2:retrofit:2.5.0'//Retrofit依賴 implementation 'com.squareup.retrofit2:converter-gson:2.5.0'//可選依賴,解析json字符所用
_
網絡權限:異步
<uses-permission android:name="android.permission.INTERNET" />
_
步驟:ide
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()); } });
_post
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()); } }); }
_
Retrofit 的註解//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 的普通添加方式
方式2:
代碼添加
方式3:
Gson:implementation 'com.squareup.retrofit2:converter-gson:2.0.2' Jackson:implementation 'com.squareup.retrofit2:converter-jackson:2.0.2'
對比 Okhttp
由於他的下層是 okhttp, 因此 hook okhttp 那一套同樣的能夠 hook Retrofit