Python如何逆向抓取APP數據

本篇內容介紹了“Python如何逆向抓取APP數據”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

成都服務器托管,創(chuàng)新互聯提供包括服務器租用、服務器托管、帶寬租用、云主機、機柜租用、主機租用托管、CDN網站加速、主機域名等業(yè)務的一體化完整服務。電話咨詢:13518219792

所需設備和環(huán)境:

  • 設備:安卓手機

  • 抓包:

  • fiddler+xposed+JustTrustme

  • 查殼:ApkScan-PKID

  • 脫殼:frida-DEXDump

  • 反編譯:jadx-gui

  • hook:frida

抓包

手機安裝app,設置好代理,打開 fiddler 先來抓個包,發(fā)現這個 app 做了證書驗證,fiddler 開啟之后 app提示連接不到服務器

Python如何逆向抓取APP數據

那就是 app 做了 SSL pinning 證書驗證,解決這種問題一般都是安裝 xposed 框架,里面有一個 JustTrustme  模塊,它的原理就是hook,直接繞過證書驗證類,安裝方法大家百度吧。

之后再打開app,可以看到成功抓到了包:

Python如何逆向抓取APP數據

先簡單分析一下,可以看到請求體中 formdata 是密文,響應內容也是密文,這個請求和響應中有用信息非常少,甚至都不知道在 jadx-gui  里怎么搜索,請求體中 formdata 是以兩個等號結尾的,應該是個 base64 編碼,其他一概不知。。。

脫殼反編譯

那先來反編譯,在這之前,通常是先用查殼工具檢查一下 app 是否加固,打開 ApkScan-PKID ,把 app 拖入:

Python如何逆向抓取APP數據

可以看到這個 app 使用了 360 加固,真是層層設限啊!!這里使用frida-DEXDump來脫殼,可以到 github 上下載  frida-DEXDump 的源代碼,完成之后打開項目所在文件夾,在當前位置打開命令行運行以下命令:

python main.py

等待脫殼完成,可以看到當前項目中生成了一個對應文件夾,里面有很多dex文件:

Python如何逆向抓取APP數據

下面用 jadx-gui 打開 dex 文件,一般先從最大的文件開始依次搜索關鍵字,我們知道 java 中使用 base64 是有  BASE64Encoder 關鍵字的,因為抓包得到的信息非常少,在這里就只能搜索這個關鍵字了,搜到第四個dex中,得到了疑似加密處:

Python如何逆向抓取APP數據

可以看到是使用了一個 aes 加密,密鑰是固定的字符串。

Frida Hook

Java不太熟,分析不來,直接使用 frida 來寫一段 hook 代碼看一看 encrypt 函數入參和出參的內容:

Python如何逆向抓取APP數據

同時來抓包對比:

Python如何逆向抓取APP數據
Python如何逆向抓取APP數據

就得到了這里的請求 data 入參數據:

  • pageIndex:當前頁碼

  • pageSize:當前頁對應的數據條數

typeId 和 source 是固定的, 接下來再來 hook decrypt 函數,對比抓包和 hook 結果:

Python如何逆向抓取APP數據
Python如何逆向抓取APP數據

結果是一樣的,至此,我們逆向分析就完成了。

總結一下請求和響應過程,就是請求體中的 data 經過 encrypt 函數加密傳參,改變 pageIndex 就可以得到每頁數據,響應是經過  decrypt 函數加密顯示,那我們只需要在 python 中實現這個 aes 加密解密過程就行了,從反編譯的 java  代碼中可以看出密鑰是固定的:wxtdefgabcdawn12,沒有 iv 偏移。

請求

直接上代碼:

Python如何逆向抓取APP數據

運行代碼,成功拿到數據:

Python如何逆向抓取APP數據

“Python如何逆向抓取APP數據”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關的知識可以關注創(chuàng)新互聯網站,小編將為大家輸出更多高質量的實用文章!

網頁題目:Python如何逆向抓取APP數據
文章來源:http://muchs.cn/article8/ihisip.html

成都網站建設公司_創(chuàng)新互聯,為您提供軟件開發(fā)、App設計、微信公眾號、網站設計、企業(yè)建站、網站維護

廣告

聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯

成都seo排名網站優(yōu)化