Charles证书安装为安卓系统证书

0.前言

用charles对手机app进行抓包时,有些app在使用了charles代理的时候会无法连接网络的情况,即便已经将charles证书安装到手机用户证书了也不行,这个时候一般考虑两种情况:

1.证书双向验证。详情可以参考://www.greatytc.com/p/22b56d977825

2.app仅信任系统证书。

关于如何区分这两种情况,我并未在网上找到明确的答案,如果有人对这方面了解的话求给小弟指条明路,感激不尽。

本文要解决的是第2种情况,出现这种情况的话直接把charles证书安装成系统证书就行了。

1.下载charles证书

打开charles,点击Help > SSL Proxying > Save Charles Root Certificate...下载证书到本地

这里有个坑,选择下载目录后,需要在文件夹名后面加上"\xxx"才会把证书下载到该目录下的xxx.pem文件,否则的话证书会下载到上一级目录,而证书名就是最后一级目录的名称,比如这里如果没有加"\chrales",那证书就会下载到D盘根目录的work.pem文件。搞的我第一次下的时候老找不到文件,重新下又说文件已存在,蛋疼。

image

2.证书格式化

系统证书和用户证书文件有很大不同,我们先进入系统证书目录看一下系统证书都长什么样,安卓系统证书都在/system/etc/security/cacerts目录下,用adb shell进入该目录,查看一下已有的证书

image

可以看到系统证书都是.0格式的,而且命名显然也是大有讲究的。

证书的名称可以用openssl获取,linux或者mac一般都有openssl,如果没有的话就自己装一个吧。使用以下命令就可以计算出证书的名字:
openssl x509 -inform PEM -subject_hash_old -in xxxx.pem | head -1

1638433493(1).jpg

得到文件名之后把证书重命名以下就可以了

mv charles.pem e03d39e3.0

3.将证书放到安卓系统证书目录

这里需要一部拥有root权限的安卓设备,建议使用夜神模拟器,直接下载最新版,默认有root权限,并且夜神模拟器自带有adb,方便下面的步骤。

利用夜神模拟器的文件传输功能将证书传到安卓模拟器,需要把证书先放到电脑夜神模拟器共享目录,然后把证书拖动到夜神模拟器窗口就完成传输了,文件会传到模拟器的共享目录。


1638433943.png

然后打开cmd,进入夜神模拟器adb目录,这个要看个人的安装目录,我的电脑是D:\Program Files\Nox\bin

然后在cmd中依次输入以下命令就行了

进入shell
adb shell
获取超级用户权限
su
修改system目录读写权限
mount -o remount,rw /system
将安卓共享目录中的证书文件复制到系统证书目录中去
cp /sdcard/Pictures/e03d39e3.0 /system/etc/security/cacerts/
开启证书权限
chmod 644 /system/etc/security/cacerts/e03d39e3.0

1638434473(1).jpg

4.设置charles

Charles默认不开启https抓包,所以我们需要进行以下设置
首先将Charles证书安装到电脑
点击Help > SSL Proxying > Install Charles Root Certificate,在弹出窗口中点击“安装证书”,然后选择安装到本地计算机,点击下一页,选择将所有证书都放入下列存储,选择受信任的根证书颁发机构,确定。

第二步开启https代理
点击Proxy > SSL Proxying Setting,勾选Enable SSL Proxying,添加代理域名/端口


1638438695(1).jpg

可以直接两个通配符代理所有https请求


image.png

经过这两步操作就可以开始抓包https请求了

5.设置设备代理

安卓模拟器中点击设置打开wifi,长按wifi修改网络


1638434657(1).jpg

填入charles代理地址后保存即可,可以在Charles中点击Help > SSL Proxying > Install Charlse Root Cetificate on a mobile device or remote browser看到ip地址和端口


image.png

全部流程走完,可以愉快的抓包了,可以用某灵魂软件去试一下,好像旧版有些是ssl pinning的,但我在模拟器安装的是3.98.0版本,用这个方法就可以抓包了。

欢迎技术交流,互相学习一起进步!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容