Python爬蟲進階必備 | 一個典型的 AES 加密在爬蟲中的應用案例
- 2019 年 10 月 31 日
- 筆記

一個典型的AES案例
AES 的案例之前有推薦大家關於 AES 加密的案例文章,不少朋友問我加密解決了有什麼用?
最大的用途當然就是不用模擬請求,大大提高了爬取效率。
可能之前舉例都是使用的 AES 加密的密碼,所以不少朋友只關注了加密沒注意實現後的用途,所以這次再寫一個其他的 AES 加密作為示例。
這個例子來自 JS 逆向課程的預售群,偶然看到有群友提問,這裡簡單分析一下。
分析加密
抓包可以看到這裡 data 部分是加密的。【圖1-1】

直接搜索 data 這個加密參數可以看到有很多的相關項【圖1-2】

那麼如何快速定位這個加密內容解密的地方呢?
我們把請求返回的內容先美化一下,看看有沒有什麼點可以追蹤一下。
可以看到在返回內容里和加密相關的欄位有一個 isEncrypt
通過參數的名字我們可以猜測這個欄位是用來標識內容是否加密。【圖1-3】

我們檢索這個欄位看看有什麼樣的結果。【圖1-4】

可以看到只有兩個相關的內容,我們在第一個找到了解密相關的內容。【圖1-5】

接下來就可以參考我前面的文章套路直接把關鍵的解密程式碼套進去就可以解密了。
可以直接套用 JS 的解密程式碼,也可以參考我們文章舉例的 Python 程式碼
Python 複寫加密
我們先把上次的 Python 程式碼 CV 過來。
import base64from Crypto.Cipher import AESimport random def pkcs7padding(text): """ 明文使用PKCS7填充 最終調用AES加密方法時,傳入的是一個byte數組,要求是16的整數倍,因此需要對明文進行處理 :param text: 待加密內容(明文) :return: """ bs = AES.block_size # 16 length = len(text) bytes_length = len(bytes(text, encoding='utf-8')) # tips:utf-8編碼時,英文佔1個byte,而中文佔3個byte padding_size = length if(bytes_length == length) else bytes_length padding = bs - padding_size % bs # tips:chr(padding)看與其它語言的約定,有的會使用'