关于面向Android7.0及以上系统的应用无法通过charles抓包

本文介绍了Android 7.0及以上版本应用因安全策略导致无法通过Charles抓包的问题,并提供了两种解决方案:1) 使用network_security_config.xml自定义网络安全设置,适用于调试环境;2) 为网络请求库如OkHttp添加证书配置,实现动态控制。同时,文章讨论了这些方法在团队协作和线上环境中的适用性。
摘要由CSDN通过智能技术生成

关于面向Android7.0及以上系统的应用无法通过charles抓包

默认情况下,来自所有应用的安全连接(使用TLS和HTTPS之类的协议)均信任预装的系统CA,而面向6.0及以下系统版本的应用默认情况下还会信任用户添加的CA证书。如果我们将targetSdkVersion修改到24以上的时候,应用则不会信任用户安装的证书了。

详细说明见官方文档

这时,当我们通过charles或其他抓包工具抓取应用的Https请求时,尽管在手机上暗安装了charles证书,则仍会显示证书链不被信任。

我们有两种解决方案,适用不同的场景。

在manifest文件中配置application的属性android:networkSecurityConfig=”@xml/network_security_config”

通过network_security_config.xml文件可以自定义网络安全设置,包括如下功能:

  • 自定义信任的证书机构:适用于自签名证书或限制应用信任系统预装证书
  • 证书固定:将应用的安全连接限制为特定的证书,适用于代理抓包、线下环境调试
  • 明文通信选择退出:防止应用意外使用明文通信
  • 仅调试重写:在debug状态设置上述限制

详细的配置可参考官方文档

那么我们为了使我们的应用信任charles的证书,可以选择证书固定或者直接信任用户安装的证书。配置如下:

固定证书:

<?xml version="1.0" encoding="utf-8"?>
<network-security-config>
    <domain-config>
        <domain includeSubdomains="true">example.com</<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值