Android https 抓包指南
為何寫本文:
雖然過去有過多次抓包經驗,但是長時間不做了,有些坑還是難以避免,比較浪費時間。所以沉澱一篇小白指南貼,節約時間。
如果要完成Android https的抓包和解析,需要完成兩步:搭建代理服務和手機端配置。
1、代理服務
本文以AnyProxy為例。
AnyProxy 是完全可以靈活配置的代理伺服器。它支援 https明文代理 ,且提供了 Web 介面便於觀測請求情況,同時支援二次開發,可以用 JavaScript 來控制代理的全部流程,搭建前端個性化除錯環境。
(1)安裝Anyproxy
網上文章非常多,本文參考:代理伺服器 AnyProxy
(2)配置https
原理:AnyProxy 解析 Https 的原理是自制根證照 rootCA 在終端信任這份證照之後,再用它簽發各個域名的二級證照,此時二級證照可以重新對各個頁面進行解析。
A. 生成 rootCA
# 最新版本生成方法
$ anyproxy-ca
也可掃描anyproxy web頁面下載
B. 開啟並信任 rootCA.crt
生成命令執行後會彈出證照所在目錄,或者根據提示找到該目錄後,雙擊開啟。
信任證照:
(3)以支援https方式啟動anyproxy
$ anyproxy --intercept
# 簡寫
$ anyproxy -i
2、手機端
(1)安裝.crt證照
正確的安裝方法有2個:
A. 設定——WiFi——高階設定——安裝證照
B. 設定——更多設定——系統安全——從SD卡安裝裡
(2)手機設定代理
A. Wi-Fi中設定
B. adb設定(親測有效)
# 設定全域性命令
adb shell settings put global http_proxy 代理IP地址:埠號
# 移除代理資訊
adb shell settings delete global http_proxy
adb shell settings delete global global_http_proxy_host
adb shell settings delete global global_http_proxy_port
adb reboot
C. 通過第三方app設定代理(暫時不建議,親測安卓實體機配置失敗)
原始碼地址
下載apk後,安裝到手機
設定代理:
# 通過執行以下命令設定代理
adb shell am start -n tk.elevenk.proxysetter/.MainActivity
# 引數說明
-e host <host> # The host ip or address for the proxy
-e port <port> # The port for the proxy
-e ssid <ssid> # The SSID of the wifi network to set proxy on(optional, will apply on the first one if empty)
-e key <shared key> # The password/key for the wifi network
-e bypass <bypass string> # The bypass string to use for proxy settings
-e reset-wifi <boolean> # Whether or not to reset the wifi settings. This flag will tell
# the tool to forget all connected networks, make a new
# network config with the SSID and key given, and then
# attempt to connect to the wifi network. If no key is given,
# the wifi network is assumed to be unprotected/open
-e clear <boolean> # A flag that will clear the proxy settings for the given SSID
常用命令:
# 在開放的 wifi 網路上設定代理,重置 wifi(reset-wifi true)
adb shell am start -n tk.elevenk.proxysetter/.MainActivity -e host <Proxy IP> -e port <Proxy Port> -e ssid <Wifi Name> -e reset-wifi true
# 用密碼設定 wifi 網路代理
adb shell am start -n tk.elevenk.proxysetter/.MainActivity -e host <Proxy IP> -e port <Proxy Port> -e ssid <Wifi Name> -e key <Wifi pwd>
# 清除代理伺服器的 SSID
adb shell am start -n tk.elevenk.proxysetter/.MainActivity -e ssid <ssid> -e clear true
相關文章
- Https抓包HTTP
- Android7.0以上使用Charles抓包HttpsAndroidHTTP
- Charles對Android手機Https請求的抓包AndroidHTTP
- 從原理到實戰,全面總結 Android HTTPS 抓包AndroidHTTP
- 通過抓包分析 HTTPSHTTP
- charles 抓包 https 亂碼HTTP
- Android平臺HTTPS抓包解決方案及問題分析AndroidHTTP
- 談談HTTPS安全認證,抓包與反抓包策略HTTP
- https 真的安全嗎,可以抓包嗎,如何防止抓包嗎HTTP
- Wireshark抓包工具解析HTTPS包HTTP
- [Tools] 使用 Charles 對 Android 應用進行 HTTPS 資料抓包AndroidHTTP
- Android 7.0 Https抓包單雙向驗證解決方案彙總AndroidHTTP
- Android App 如何防止抓包AndroidAPP
- 介面測試之抓包實戰解決 Android 高版本無法抓取 httpsAndroidHTTP
- Android 使用Fiddler4抓包Android
- 最新使用Charles進行HTTPS抓包的方法HTTP
- 一步一步教你 https 抓包HTTP
- 扯一扯HTTPS單向認證、雙向認證、抓包原理、反抓包策略HTTP
- android開發--防止介面被抓包Android
- 手機抓包+注入黑科技HttpCanary——最強大的Android抓包注入工具HTTPPCAAndroid
- 抓包Http/Https/Other資料包(小迪網路安全筆記~HTTP筆記
- Https、SSL/TLS相關知識及wireShark抓包分析HTTPTLS
- 使用 charles 或 Fiddle 抓 Android 手機包Android
- 最簡明的 Tcpdump 抓包入門指南TCP
- 測試必備工具之抓包神器 Charles 如何抓取 https 資料包?HTTP
- 你會抓https和移動端的包嗎?分別描述下這兩種包要怎麼抓?HTTP
- [網路]從wireshark抓包看百度的https流程HTTP
- 為什麼用抓包工具看HTTPS包是明文的HTTP
- 解釋下為什麼抓包 https 需要安裝證書HTTP
- Mac 上fiddler與charles 抓包https 小程式請求 內容MacHTTP
- Flutter 跨端網路抓包 (以Android 為例)Flutter跨端Android
- iOS的http/https請求——十分鐘學會Charles抓包iOSHTTP
- tcpdump抓包TCP
- 一次app抓包引發的Android分析(續)APPAndroid
- android 模擬器 記憶體修改, 用winshark 抓包,修改資料包Android記憶體
- iOS防止抓包iOS
- mitmproxy grpc 抓包MITRPC
- iOS Wireshark抓包iOS