夜神模拟器中app抓不到包--安装证书到系统根证书

本文记录了在安卓7.0及以上系统中,使用BurpSuite抓包时遇到的证书验证失败问题及解决方法。由于系统从7.0开始仅信任预装CA证书,解决方案是将BurpSuite证书转为系统证书。具体步骤包括:使用openssl将der证书转为pem证书,生成hash值,然后通过adb将证书推送到系统证书目录。该方法适用于夜神模拟器等环境。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.起因

第一次测试app,按照正常的流程将BurpSuite生成的证书导入到夜神模拟器中,但打开app开始抓包时显示证书验证失败,当时也是一脸懵逼,此篇文章也是记录一下遇到的问题。

思路:

1 、使用openssl将der证书转为pem证书,生成pem证书的hash,

charles证书无法安装的原因是因为安卓高版本7.0之后,模拟器无法下载证书。谷歌修改安卓系统,7.0之后,app只信任指定证书系统内置的证书,后续用户安装证书不生效,故只能想办法将证书安装系统内部。具体操作步骤如下: 1. 准备pem证书。打开Charles软件,点击help下载charles.cer文件到桌面。然后下载并安装OpenSSL,并将OpenSSL的路径添加到系统变量中的path中。 2. 进行证书格式转换。在Windows的命令行中执行以下命令:将pem证书转换为cer证书:openssl x509 -outform der -in demo.pem -out demo.cer;将cer证书转换为pem证书:openssl x509 -inform der -in "C:\Users\Desktop\CharlesCA.cer" -out "C:\Users\Desktop\ca.pem"。 3. 在模拟器中操作。如果是使用模拟器,打开根目录下的nox_adb.exe文件,并通过命令行操作该文件。首先,使用命令no_adb.exe devices查看连接状态;然后,判断是否具有root权限,如果没有,则在模拟器中启用root权限并重启模拟器;最后,将/system部分置于可写入模式,执行命令adb remount。 4. 查看证书信息hash值。使用命令openssl x509 -subject_hash_old -in "C:\Users\Desktop\ca.pem"获取证书的哈希值,并将该文件重命名为哈希值加上".0"的形式,例如02631509.0。 5. 将证书复制到系统文件夹中。使用adb命令将证书文件复制到证书文件夹中,执行命令adb push 02631509.0 /system/etc/security/cacerts/。 这样,你就可以成功将Charles证书安装模拟器系统中了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值