架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 9377|回复: 2

Android 7.0 之后抓包 unknown 和证书无效的解决方案

[复制链接]
发表于 2019-3-18 21:38:06 | 显示全部楼层 |阅读模式
背景

使用抓包软件(以 Charles 为例)抓取APP的 https 请求时,Android和Charles都正确安装了证书却出现抓包失败,报错:

Client SSL handshake failed: An unknown issue occurred processing the certificate (certificate_unknown)

20180330132929243.png

原因

Android7.0 之后默认不信任用户添加到系统的CA证书:

To provide a more consistent and more secure experience across the Android ecosystem, beginning with Android Nougat, compatible devices trust only the standardized system CAs maintained in AOSP.


文档链接:https://android-developers.googl ... ed-certificate.html

也就是说对基于 SDK24 及以上的APP来说,即使你在手机上安装了抓包工具的证书也无法抓取 https 请求。

解决方案

一、官方解决方案(需修改代码)

官方文档:https://developer.android.google ... ecurity-config.html
详细演示:https://blog.csdn.net/mrxiagc/article/details/75329629

二、将抓包软件的证书安装成系统证书(需ROOT)

系统证书目录:/system/etc/security/cacerts/

其中的每个证书的命名规则如下:
<Certificate_Hash>.<Number>

文件名是一个Hash值,而后缀是一个数字。

文件名可以用下面的命令计算出来:


后缀名的数字是为了防止文件名冲突的,比如如果两个证书算出的Hash值是一样的话,那么一个证书的后缀名数字可以设置成0,而另一个证书的后缀名数字可以设置成1

操作步骤:

将抓包软件的证书用上述命令计算出 Hash 值,将其改名并复制到系统证书目录

20180330140909423.png

此时你应该可以在 设置->安全->加密与凭据->信任的凭据 的系统标签页看到你新加入的证书,将其启用即可顺利抓包

20180330140221230.png





上一篇:前端JavaScript面试技巧
下一篇:登陆页面怎么实现验证码校验?????
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2019-3-19 09:13:25 | 显示全部楼层
请问楼主,有些应用APP走代理抓包就会出现网络连接失败,不知道可以怎么样解决?
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
发表于 2019-9-6 22:55:58 | 显示全部楼层
看看老大的
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-26 07:04

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表