使用Charles对自己开发的 App在Android7.0以上的手机的https请求抓包——亲测有效

移动开发的时候经常要调试接口,如果不能抓包看接口数据,那就太痛苦了。charles能抓包,但自从Android7.0以后,对于https就不能抓包。网上查了好多方法,对https请求进行抓包,都不好使。不是显示unkown就是有内容但是乱码。经过多方尝试,终于弄出来了。

如下图:

下面写一下我的配置步骤:

1. 电脑上下载安装charles,Android手机配置代理,和电脑同一个wifi。

2.手机安装ssl证书:下载地址

3.自己的代码里添加https支持抓包的配置(关键步骤)

    在res创建一个xml目录,里面放一个network_security_config.xml,内容如下:

<!--Android9.0 进行https请求需要的配置。发生产包用这个配置-->
<!--<network-security-config>-->
    <!--<base-config cleartextTrafficPermitted="true" />-->
<!--</network-security-config>-->

<!--能抓https数据包的配置,测试包用这个配置-->
<network-security-config>
    <base-config cleartextTrafficPermitted="true">
        <trust-anchors>
            <certificates src="system" overridePins="true" />
            <certificates src="user" overridePins="true" />
        </trust-anchors>
    </base-config>
</network-security-config>

在Manifest.xml的application标签中配置上面写的文件:android:networkSecurityConfig="@xml/network_security_config"

4. charles进行配置:Proxy->SSL Proxying Settings ->add 你要抓包的https地址(不用带https),端口写443

正常的话经过以上4步就可以抓到自己程序的https请求了。

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值