iOS 设备网络通信数据抓包

发布于 2022-03-26 12:45:29 字数 1356 浏览 1265 评论 0

工具准备

  • XCode
  • tcpdump/wireshark
  • rvictl(mac 系统自带)

步骤

在iOS5中新引入了“远程虚拟接口(remote virtual interface ,RVI)“的特性,可以在Mac中建立一个虚拟网络接口来作为iOS设备的网络栈,这样所有经过iOS设备的流量都会经过此虚拟接口,此虚拟接口代替了iOS设备本身的协议栈,但并没有将网络流量中转到Mac本身的网络连接上,这样所有网络连接都是iOS设备本身的,Mac电脑本身连不联网或者连接的网络类型都没有关系,而iOS设备本身可以为任意网络类型,2G/3G/WiFi等。在 Mac 电脑上使用任意抓包工具抓取RVI接口上的数据包就可以看到iOS设备上的所有网络数据。

  1. USB连接iDevice到Mac上
  2. 获取 iDevice 的 UDID
    • 可以使用 XCode 的 organizer 查看
    • 也可以通过 iTools 查看
  3. 创建 RVI 接口
    $ rvictl -s <UDID>
    

RVI 的命名规则为 rvi0,rvi1...

查看所开启的RVI

$ rvictl -l

可用如下命令查看

$ ifconfig rvi0
  1. 现在就用相关的抓包软件抓去这个rvi上的网路连接吧
  2. 使用结束移除RVI
    $ rvictl -x <UDID>
    

注意:
如果rvictl失败并提示 bootstrap_look_up(): 1102
那可能是com.apple.rpmuxd没有正确启动,使用一下命令查看下

$ sudo launchctl list com.apple.rpmuxd

如果失败了,说明没有加载,你可以用下面命令强制加载

$ sudo launchctl load -w /System/Library/LaunchDaemons/com.apple.rpmuxd.plist

参考文献

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

文章
评论
84963 人气
更多

推荐作者

微信用户

文章 0 评论 0

小情绪

文章 0 评论 0

ゞ记忆︶ㄣ

文章 0 评论 0

笨死的猪

文章 0 评论 0

彭明超

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文