当前位置: 首页 > article >正文

Android 14/15抓包实战:从系统证书注入到应用进程级捕获

1. Android 14/15抓包的核心挑战最近在给公司做安全测试时遇到了一个头疼的问题新采购的一批Android 14/15设备死活抓不到HTTPS包。折腾了整整两天才发现原来是系统证书存储机制发生了重大变化。传统方法把证书放到/system/etc/security/cacerts完全失效了这让我这个老手也栽了跟头。Android 14开始Google引入了APEX模块化机制证书存储路径改到了/apex/com.android.conscrypt/cacerts。这个目录受到SELinux严格保护就算有root权限也很难直接修改。更麻烦的是很多厂商设备现在默认都锁了bootloader根本没法持久化修改系统分区。我测试过市面上主流的抓包方案直接导入用户证书Android 7以下有效修改系统证书目录Android 13以下有效各种抓包工具的VPN模式部分应用会检测结果发现在Android 14/15上这些方法全军覆没。特别是金融类App基本都启用了证书固定Certificate Pinning连Frida hook都变得异常困难。经过反复实验终于摸索出一套可行的组合拳方案。2. 临时注入系统证书的实战方案2.1 动态挂载证书目录的黑科技传统方案是直接修改系统分区但在新设备上这招已经行不通了。我的解决方案是利用tmpfs内存文件系统动态挂载#!/system/bin/sh # 创建临时证书目录 mkdir -p -m 700 /data/local/tmp/tmp-ca-copy # 复制原有证书 cp /apex/com.android.conscrypt/cacerts/* /data/local/tmp/tmp-ca-copy/ # 挂载tmpfs到系统证书目录 mount -t tmpfs tmpfs /system/etc/security/cacerts # 迁移证书并添加自定义CA mv /data/local/tmp/tmp-ca-copy/* /system/etc/security/cacerts/ cp /data/local/tmp/your_ca.0 /system/etc/security/cacerts/ # 设置权限和SELinux上下文 chmod 644 /system/etc/security/cacerts/* chcon u:object_r:system_file:s0 /system/etc/security/cacerts/*这个脚本的精妙之处在于完全在内存中操作不修改物理分区保持原有证书不丢失通过SELinux权限检查2.2 进程级证书注入技巧光挂载还不够必须让所有进程看到新证书。这里需要用到Linux的namespace技术# 获取zygote进程ID ZYGOTE_PID$(pidof zygote || true) ZYGOTE64_PID$(pidof zygote64 || true) # 注入到zygote的mount namespace for Z_PID in $ZYGOTE_PID $ZYGOTE64_PID; do if [ -n $Z_PID ]; then nsenter --mount/proc/$Z_PID/ns/mnt -- \ /bin/mount --bind /system/etc/security/cacerts /apex/com.android.conscrypt/cacerts fi done # 处理已启动的应用进程 APP_PIDS$(ps -o PID -P $ZYGOTE_PID $ZYGOTE64_PID | grep -v PID) for PID in $APP_PIDS; do nsenter --mount/proc/$PID/ns/mnt -- \ /bin/mount --bind /system/etc/security/cacerts /apex/com.android.conscrypt/cacerts done实测发现有些应用会自己重新挂载namespace所以最好每隔10秒重新执行一次注入。可以用while循环配合sleep实现自动化。3. 应用级流量精准捕获3.1 基于tcpdump的进程过滤证书问题解决后接下来就是精准抓包。我最推荐tcpdumpwireshark组合# 查找目标应用进程 ps -Ao PID,NAME,ARGS | grep com.target.app # 获取该进程使用的端口 netstat -anp | grep PID # 抓取特定端口流量 tcpdump -i wlan0 -s0 -w /sdcard/capture.pcap port 443 or port 8080这里有几个实用技巧用-s0参数确保抓完整数据包WiFi和移动网络要分别抓wlan0 vs rmnet_data0复杂过滤条件可以保存到文件用-F参数加载3.2 高级过滤技巧遇到这些特殊情况可以这样处理IPv6流量添加ip6过滤条件QUIC协议抓取UDP 443端口WebSocket过滤tcp[((tcp[12:1] 0xf0) 2):4] 0x47455420推荐保存常用过滤规则# HTTP请求头捕获 tcpdump -i any -A tcp[((tcp[12:1] 0xf0) 2):4] 0x47455420 # 抓取DNS查询 tcpdump -i any -s0 -A udp port 534. 疑难问题解决方案4.1 证书仍然不生效遇到过几次脚本执行成功但证书就是不生效的情况通常是因为应用使用了自定义TrustManager系统启用了hardened_mallocSELinux策略阻止了mount操作解决方案分三步走检查SELinux审计日志dmesg | grep avc临时放宽SELinuxsetenforce 0用strace跟踪SSL握手过程strace -f -e traceopenat -p APP_PID4.2 应对证书固定Pinning对于使用证书固定的应用可以尝试Xposed模块TrustMeAlreadyFrida脚本Java.perform(function() { var Certificate Java.use(java.security.cert.Certificate); Certificate.verify.implementation function() { console.log(Bypassing certificate verification); }; });内核模块手动修改内核中的证书校验函数5. 自动化脚本集我把常用操作封装成了几个实用脚本cert_inject.sh证书注入#!/system/bin/sh # 自动识别Android版本 if [ -d /apex/com.android.conscrypt ]; then # Android 14方案 ./inject_apex.sh else # 传统方案 mount -o rw,remount /system cp *.0 /system/etc/security/cacerts/ chmod 644 /system/etc/security/cacerts/* mount -o ro,remount /system ficapture.sh智能抓包#!/system/bin/sh # 自动选择网卡 INTERFACE$(ip route | awk /default/ {print $5}) # 智能识别HTTP/HTTPS端口 PORTS$(netstat -tuln | awk /LISTEN/ {print $4} | awk -F: {print $NF} | sort -u) # 开始抓包 tcpdump -i $INTERFACE -s0 -w /sdcard/$(date %s).pcap port ($(echo $PORTS | tr |))这些脚本我都放在Gist上持续更新建议保存到设备的/data/local/tmp目录下使用。

相关文章:

Android 14/15抓包实战:从系统证书注入到应用进程级捕获

1. Android 14/15抓包的核心挑战 最近在给公司做安全测试时,遇到了一个头疼的问题:新采购的一批Android 14/15设备死活抓不到HTTPS包。折腾了整整两天才发现,原来是系统证书存储机制发生了重大变化。传统方法把证书放到/system/etc/security/…...

TimesFM时间序列预测:谷歌基础模型让零样本预测变得如此简单

TimesFM时间序列预测:谷歌基础模型让零样本预测变得如此简单 【免费下载链接】timesfm TimesFM (Time Series Foundation Model) is a pretrained time-series foundation model developed by Google Research for time-series forecasting. 项目地址: https://gi…...

新手小白实战教程:用 TRAE 从零创建一个“个人日记本”网页应用

本教程将带你手把手、一步步,使用 TRAE 完成你的第一个小项目。我们会像搭积木一样,从创建一个空文件夹开始,直到做出一个能运行、能记日记的简单网页。请严格按顺序操作,不要跳步。 第一步:项目启动与规划 (5分钟) 目…...

PCB设计老鸟的AD21 DRC设置清单:如何为你的高速板与低速板定制专属检查规则

PCB设计高手必备:AD21 DRC规则定制化配置实战指南 在PCB设计领域,DRC(设计规则检查)就像是一位严格的质检员,它能帮我们提前发现设计中潜在的问题。但很多工程师都面临一个困境:面对不同类型的设计项目&…...

《TRAE从入门到精通全攻略》,零基础也能快速上手,助力你快速成长为程序员

TRAE 从入门到精通:一站式完整指南 本指南将带你从零开始,系统性地掌握字节跳动推出的智能编程助手 TRAE。我们将按照“获取-安装-认识-使用-精通”的路径,逐一解析其所有核心功能与界面。 第一部分:获取与安装 1. 系统要求与下…...

MDAnalysis解决方案:分子动力学模拟分析效能提升框架

MDAnalysis解决方案:分子动力学模拟分析效能提升框架 【免费下载链接】mdanalysis MDAnalysis is a Python library to analyze molecular dynamics simulations. 项目地址: https://gitcode.com/gh_mirrors/md/mdanalysis 问题痛点引入:分子动力…...

国民技术 N32G452CCL7 LQFP-48 单片机

特性32位ARM Cortex-M4内核 FPU,单周期硬件乘除法指令,支持DSP指令和MPU内置8KB指令Cache缓存,支持Flash加速单元执行程序0等待最高主频144MHz,180DMIPS高达512KByte片内Flash,支持加密存储、多用户分区管理及数据保护…...

宝塔面板卸载后网站数据还在吗?保姆级清理与重装避坑指南

宝塔面板卸载后数据安全完全指南:从残留清理到重装避坑全解析 每次面对服务器环境重构时,最令人头疼的莫过于那些"看不见的数据幽灵"——你以为已经卸载干净的软件,实际上在系统深处留下了各种配置文件、日志和缓存。作为国内使用率…...

3分钟搞定!Windows包管理器Winget一键安装终极方案

3分钟搞定!Windows包管理器Winget一键安装终极方案 【免费下载链接】winget-install Install WinGet using PowerShell! Prerequisites automatically installed. Works on Windows 10/11 and Server 2019/2022. 项目地址: https://gitcode.com/gh_mirrors/wi/win…...

War3地图编辑器进阶:利用炮火攻击实现混乱伤害技能的完整指南

War3地图编辑器进阶:炮火攻击实现混乱伤害技能的深度解析 在魔兽争霸3地图编辑器的世界里,创造独特技能是每位地图作者的必修课。传统技能往往受限于固定伤害值或特定攻击类型,而今天我们要探讨的是一种突破常规的方法——利用炮火攻击地面机…...

Dify聊天框太丑?手把手教你从嵌入代码到Docker镜像的完整UI定制流程

Dify聊天框太丑?手把手教你从嵌入代码到Docker镜像的完整UI定制流程 当你第一次将Dify聊天机器人嵌入到自己的网站时,可能会对那个蓝色气泡和千篇一律的对话框感到失望。作为开发者或产品经理,你一定希望这个智能助手能完美融入品牌风格&…...

【计算机网络 实验报告2】网络常用命令与基本配置

上一篇:【计算机网络 实验报告1】Wireshark软件的使用 目录 实验目的 二、实验环境 三、实验内容 四、实验过程与结果 五、习题 实验目的 学习网络常用命令学习Packet Tracer软件的使用学习网络的基本配置方法 二、实验环境 设备名称 DESKTOP-F3VC3QK 处…...

RevokeMsgPatcher:Windows平台微信/QQ/TIM防撤回解决方案深度解析

RevokeMsgPatcher:Windows平台微信/QQ/TIM防撤回解决方案深度解析 【免费下载链接】RevokeMsgPatcher :trollface: A hex editor for WeChat/QQ/TIM - PC版微信/QQ/TIM防撤回补丁(我已经看到了,撤回也没用了) 项目地址: https:/…...

TurboVNC完整安装与配置指南:高性能远程桌面解决方案

TurboVNC完整安装与配置指南:高性能远程桌面解决方案 【免费下载链接】turbovnc Main TurboVNC repository 项目地址: https://gitcode.com/gh_mirrors/tu/turbovnc TurboVNC是一个专为高性能图形应用优化的远程桌面系统,特别适合3D渲染、视频处理…...

大模型修炼秘籍 第十章:多才多艺——多任务微调

第十章:多才多艺——多任务微调多任务修多才艺,混合数据需平衡。【本章导读】 真正的大模型应该文能提笔安天下,武能上马定乾坤。多任务微调让模型学会多种技能,成为全能选手。一、一专多能 【任务类型】任务类型描述示例文本生成…...

遗传算法实战:解码带时间窗约束的车辆路径规划(VRPTW)

1. 当物流遇上时间窗:VRPTW问题到底有多难? 想象一下你是一家生鲜电商的物流调度员,早上6点打开系统,屏幕上突然弹出16个新订单:王阿姨要7:30-8:00收到活鱼,李大爷要求8:15-8:45配送新鲜蔬菜,而…...

2026届必备的六大AI写作平台横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 人工智能技术发展势头迅猛,速度极快,为毕业论文写作带来了全新的辅助…...

从MODE到INTERCONNECT:环形谐振器电路级仿真全流程解析(含Lumerical脚本示例)

从MODE到INTERCONNECT:环形谐振器电路级仿真全流程解析 硅光集成设计中最令人着迷的挑战之一,是如何将精确的光学仿真结果无缝转化为电路级设计语言。想象一下,当你花费数小时在FDTD中优化出一个Q值超过10000的环形谐振器后,却发…...

建站系统怎么选?2026年SaaS平台与开源CMS对比分析

建站系统是指用于创建、管理和维护网站的软件平台或工具集,其核心目标是通过标准化模块降低网站开发的技术门槛,让用户无需从零编写代码即可完成网站搭建与内容管理。从技术架构与部署模式角度,当前建站系统主要分为两大类别:一、…...

从寄存器配置到数据解析:基于STM32与MAX31856的E型热电偶测温实战

1. 工业测温场景下的E型热电偶方案选型 在工业温度测量领域,热电偶因其宽量程、高可靠性和快速响应等特点成为首选传感器。E型热电偶(镍铬-铜镍)在0-900℃范围内具有最高的灵敏度(68μV/℃),特别适合中低温…...

2025年八大网盘直链下载工具LinkSwift完整使用指南:告别限速,实现全速下载

2025年八大网盘直链下载工具LinkSwift完整使用指南:告别限速,实现全速下载 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / …...

LIS3DHTR三轴加速度计:从智能穿戴到工业监测的全场景应用解析

1. LIS3DHTR三轴加速度计的核心特性解析 第一次接触LIS3DHTR时,我完全被这个小芯片的"反差萌"震惊了——尺寸只有3x3x1mm的LGA封装里,竟然藏着能感知16g加速度的精密机械结构。这款意法半导体的明星产品采用MEMS工艺,内部其实是个&…...

平衡树的本质的庖丁解牛

它的本质是:通过引入额外的维护成本(旋转、变色、重新平衡),强制将二叉搜索树 (BST) 的高度控制在 O(log⁡n)O(\log n)O(logn) 级别,从而保证在最坏情况下,查找、插入、删除操作的时间复杂度依然稳定。它是…...

从论文到GitHub:手把手复现TCom顶会混合波束成形MMSE算法(含Python/Matlab代码解析)

从论文到工程实践:混合波束成形MMSE算法的代码级拆解与性能优化 在毫米波通信系统中,混合波束成形技术因其在硬件复杂度和系统性能间的平衡而备受关注。当我们从论文转向实际代码实现时,理论公式与工程实践之间往往存在巨大鸿沟。本文将带您深…...

网安人必藏!Web 安卓 APP 软件逆向知识点

那么说到这我们更通俗的来表达一下,正向就像工厂生产一个产品,而逆向了就像你小时候败家的样子,总喜欢把一些玩具或者电子电器拆开研究一下他里面有啥,他是怎么运行的,当然绝大多数情况下,你一定挨了不少骂…...

STM32-结构体对齐与内存池实战优化

1. 为什么STM32开发者必须掌握结构体对齐与内存池 第一次在STM32上实现CAN总线通信时,我遇到了一个诡异的问题:接收到的数据总是错位。调试了整整两天才发现,问题出在结构体成员没有按4字节对齐,导致DMA传输时数据地址不符合硬件要…...

Node.js实战:手把手教你调用EduCoder实训平台API(附完整封装代码)

Node.js实战:从零封装EduCoder平台API的完整指南 在编程学习过程中,实训平台扮演着至关重要的角色。EduCoder作为国内知名的在线编程实训平台,提供了丰富的编程练习和项目实战机会。但对于开发者而言,如何通过程序化方式与平台交互…...

企业级百度云自动化管理终极指南:bypy命令行工具深度解析

企业级百度云自动化管理终极指南:bypy命令行工具深度解析 【免费下载链接】bypy Python client for Baidu Yun (Personal Cloud Storage) 百度云/百度网盘Python客户端 项目地址: https://gitcode.com/gh_mirrors/by/bypy 在当今企业数字化转型浪潮中&#x…...

炉石传说HsMod插件:55项功能全面指南与高效安装教程

炉石传说HsMod插件:55项功能全面指南与高效安装教程 【免费下载链接】HsMod Hearthstone Modification Based on BepInEx 项目地址: https://gitcode.com/GitHub_Trending/hs/HsMod HsMod是基于BepInEx框架开发的炉石传说多功能插件,为玩家提供全…...

PHP SAAS 框架常见问题——配置问题——小程序消息推送配置 Token 校验失败

小程序消息推送配置 Token 校验失败问题:小程序消息推送配置提示 Token 校验失败,请检查确认解决办法:要先把商城后台的填好保存以后再来这里提交...