抖音數據採集教程,Retrofit 開發與 hook

抖音數據採集教程,Retrofit 開發與 hook

短視頻、直播數據實時採集接口,請查看文檔: TiToDataandroid


免責聲明:本文檔僅供學習與參考,請勿用於非法用途!不然一切後果自負。json

Retrofit

文中全部 Retrofit 都是指的 Retrofit2api

Retrofit其實咱們能夠理解爲OkHttp的增強版,它也是一個網絡加載框架。
底層是使用OKHttp封裝的。準確來講,網絡請求的工做本質上是OkHttp完成,網絡

而 Retrofit 僅負責網絡請求接口的封裝。它的一個特色是包含了特別多註解,
方便簡化你的代碼量。
優勢:app

  1. 超級解耦
  2. 能夠配置不一樣HttpClient來實現網絡請求
  3. 支持同步、異步和RxJava
  4. 能夠配置不一樣的反序列化工具來解析數據,如:json、xml
  5. 請求速度快,使用很是方便靈活
Retrofit 使用

配置依賴:框架

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

  1. 定義接口類(封裝URL地址和數據請求)
  2. 實例化Retrofit
  3. 經過Retrofit實例建立接口服務對象
  4. 接口服務對象調用接口中的方法,獲取Call對象
  5. Call對象執行請求(異步,同步請求)

建立 Retrofit 實例

Retrofit retrofit = new Retrofit.Builder()
        .baseUrl("http://localhost:6666")
        .build();

_工具

Get請求

//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

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);

_

設置 headers

方式1:

這是單個 headers 和 多個 headers 的普通添加方式
方式2:

代碼添加
方式3:

數據解析 (Converter)
  • Retrofit 支持多種方式數據解析
  • 須要在Geadle中添加依賴
Gson:implementation 'com.squareup.retrofit2:converter-gson:2.0.2'
Jackson:implementation 'com.squareup.retrofit2:converter-jackson:2.0.2'


對比 Okhttp

  • 準確來講,Retrofit 是一個 RESTful 的 HTTP 網絡請求框架的封裝。
  • 緣由:網絡請求的工做本質上是 OkHttp 完成,而 Retrofit 僅負責 網絡請求接口的封裝
  • App應用程序經過 Retrofit 請求網絡,其實是使用 Retrofit 接口層封裝請求參數、Header、Url 等信息,以後由 OkHttp 完成後續的請求操做
  • 在服務端返回數據以後,OkHttp 將原始的結果交給 Retrofit,Retrofit根據用戶的需求對結果進行解析
Hook

由於他的下層是 okhttp, 因此 hook okhttp 那一套同樣的能夠 hook Retrofit

相關文章
相關標籤/搜索