使用Mac抓取iPhone数据包(二.RVI)

本文介绍iOS5新增的远程虚拟接口(RVI)特性,可在Mac上建立虚拟网络接口来抓取iOS设备的所有网络数据,包括2G/3G/WiFi等多种网络类型的数据包。文中详细解释了RVI的使用方法,包括通过USB连接iPhone至Mac、使用Xcode获取iPhone UDID以及使用rvictl命令创建和删除RVI。

转自:http://www.winddisk.com/2012/09/01/mac_capture_iphone_package_remote_virtual_interface/


一.Remote Virtual Interface

使用Mac抓取iPhone数据包中介绍了两种方式在Mac电脑上抓取iPhone上的数据包,一是使用Mac的网络共享功能将Mac的网络通过WiFi共享给iPhone连接,一是使用代理软件在Mac上建立HTTP代理服务器;这两种方式都是将iPhone的网络流量导入到Mac电脑中,通过Mac连接互联网,这就要求Mac本身是联网的,对于网络共享的方式还要求Mac本身的网络不能使用WiFi,而且在iPhone上全是使用的WiFi连接,不能抓取2G/3G网络的包。

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

二.使用方法

  1. 通过USB口将iPhone连接到Mac上。
  2. 使用Xcode的organizer工具获取到iPhone的UDID
  3. 使用rvictl命令创建RVI接口(remote virtual interface),使用iPhone的UDID作为参数。
    $ rvictl -s <UDID>

    如果想捕获多个设备的网络包,可以使用上述命令创建多个设备的RVI,传递每个iOS设备的UDID作为参数即可。
    RVI虚拟接口的命名规则为rvi0,rvi1,rvi2,…,可使用ifconfig命令查看

    $ ifconfig rvi0
     rvi0: flags=3005<UP,DEBUG,LINK0,LINK1> mtu 0
  4. 在Mac上使用任意抓包工具tcpdump、wireshark等,监听创建的rvi接口即可。
  5. 使用完之后需要将创建的虚拟接口移除
    $ rvictl -x <UDID>

参考:
Technical Q&A QA1176 – Getting a Packet Trace
Remote Packet Capture for iOS Devices
WWDC 2011 – Core OS Networking In-Depth Presentation Slides


Mac使用 Wireshark 连接手机进行网络抓包,主要可以通过以下几种方式实现: ### 1. 使用远程虚拟接口(RVI抓取 iPhone 流量 苹果从 iOS 5 开始引入了远程虚拟接口(Remote Virtual Interface, RVI)功能,允许 Mac 建立一个虚拟网络接口来监听 iOS 设备的网络流量。具体操作步骤如下: - 确保 iPhoneMac 处于同一网络环境中,并通过 USB 数据线连接。 - 在终端中执行命令 `rvictl -s <设备UDID>` 来创建 RVI 接口。可以通过 `system_profiler SPUSBDataType` 获取设备的 UDID。 - 打开 Wireshark,选择新创建的 RVI 接口(如 `rvi0`),即可开始抓包。 - 完成后,使用 `rvictl -x <设备UDID>` 命令关闭 RVI 接口。 该方法不会影响 Mac 的网络连接,所有流量均由 iOS 设备本身处理[^3]。 ### 2. 使用 Wireshark 抓取 Android 设备流量 对于 Android 设备,可以通过以下方式实现抓包: - **使用 tcpdump 抓包并导出文件**:在 Android 设备上安装支持抓包的工具(如 tcpdump 或专用应用),将抓取数据包保存为 `.pcap` 文件,然后将其复制到 Mac 上,使用 Wireshark 打开进行分析。 - **使用远程抓包工具**:某些 Android 设备或 Root 后的设备可以配合远程抓包工具(如 Shark for Root),将抓包数据实时传输到 Mac 上的 Wireshark 进行查看。 ### 3. 使用共享网络连接的方式 如果希望直接在 Mac 上实时查看手机流量,也可以通过共享网络连接的方式实现: - 将手机通过 USB 连接到 Mac,并开启 USB 网络共享功能。 - 在 Mac 上配置共享网络,确保流量经过 Mac 转发。 - 在 Wireshark 中选择 Mac 上用于共享网络的接口(如 `en0` 或 `bridge0`),即可捕获经过该接口的流量。 ### 4. 使用无线网络抓包 如果手机和 Mac 处于同一 WiFi 网络中,也可以通过以下方式实现抓包: - 在 Mac使用 Wireshark 抓取 WiFi 接口上的流量,确保处于混杂模式以便捕获其他设备的数据包。 - 如果路由器支持,可以将手机流量镜像到 Mac 所在的端口,再通过 Wireshark 抓取镜像流量。 ### 示例:使用 Wireshark 抓取 RVI 接口流量 ```bash # 查看 iPhone 的 UDID system_profiler SPUSBDataType # 创建 RVI 接口(假设设备 UDID 为 1234567890abcdef) rvictl -s 1234567890abcdef # 在 Wireshark 中选择 rvi0 接口开始抓包 # 完成后关闭 RVI 接口 rvictl -x 1234567890abcdef ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值