Charles是一款非常实用的抓包工具。它通过电脑端代理,拦截网络请求和响应来实现数据包的抓取。支持http/https。
安装
Charles需要Java环境,在安装之前确保已有配置Java运行环境。然后到官网下载Charles并安装。破解的话,可以使用网友提供的工具: Charles 在线破解。
设置
打开Charles抓包工具:

电脑端设置代理:Proxy —> Proxy Setting:

端口号填写8888,并选中Enable transparent HTTP proxying。
Android手机端设置:首选将手机和电脑连接在同一无线局域网上(同一个路由器)。然后利用cmd-ipconfig查看自己电脑的ip:

然后在手机wifi连接中进行设置:

这里代理设置选择手动,主机名即是电脑的局域网ip,端口号为电脑端Charles设置的端口号。
抓取http数据
安卓上面的步骤就设置完成了。我们使用小米商城app来试一下抓取的数据包。
手机端打开小米商城:

同时监测电脑端Charles的数据抓取:

需要自己筛选一下,可以看到红框中就是小米商城http请求的域名,点开可以看到详细的网络请求接口:

点击选中对应的接口,在右侧可以看到抓包的结果,选中Contents可以看到抓取的内容,上部分为请求的数据包,有Headers、Cookie、请求体的Text/Hex/Form形式。下部分为响应的数据包。包括有Headers、响应结果Json、JsonText等形式。

抓取https数据包
上面的方式只能抓取到http数据包,要抓https还需要安装证书。
首先安装电脑端的CA证书:Help —> SSL Proxyging —> Install Charles Root Certificate:

安装证书:

下一步:

将所有证书都放入下列储存 —> 浏览 —> 受信任的根证书颁发机构 —> 确定 —> 下一步:

最后点击完成。
安卓手机端安卓证书:很多手机通过浏览器下载证书安装会提示无法安装,所以这里通过在电脑上下载好手机端的证书,传到手机上再来安装。
在浏览器中地址中输入chsl.pro/ssl,下载手机端证书并传到手机储存上:

在手机设置里面找到系统安全/安全与隐私(小米5手机:设置 —> 更多设置 —> 系统安全)

找到之前存放证书的位置,选择证书文件:

输入证书名称charles,点击确定,安装完成。
通过小米商城lite的微信小程序来测试下抓取https数据包。打开微信小程序“小米商城Lite”,点击页面跳转。并监测Charles抓取的数据:

可以看到这就抓取到了小米商城Lite小程序的https请求数据包。
网友评论