如何利用Android设备实现Wi-Fi嗅探(mon模式)

6次阅读
没有评论

如何将Android设备转换为Wi-Fi嗅探器(使用mon模式)

介绍

本文探讨了如何通过网络抓包工具tcpdump将Android手机改造为一个被动的Wi-Fi嗅探器。具体来说,我们将通过调整配置和安装相关软件来实现在Android上使用mon模式运行tcpdump

所需设备及环境

  1. 具有高通WiFi芯片组的 Android 设备:尽管高通的大部分芯片组都不支持这种用法。
  2. root权限:因为需要对内核进行一些修改或安装必要的软件包。
  3. ADB shell访问:通过USB线连接设备,使用adb shell命令进行操作。

实现步骤

  1. 检查WiFi状态: 在ADB shell下,运行 ifconfig -a 或者 ip link show 命令确认是否有与WLAN相关的接口,如wlan0。部分手机可能是eth0或者rmnetX格式命名。
    sh
    adb shell ifconfig -a

  2. 确保支持的芯片组: 由于高通大部分芯片都只提供管理模式而不支持mon模式,在运行 ifconfig -aip link show 结果中查找是否包含 wlan0。如果是使用Broadcom 4330这样的芯片组,则理论上可实现。

根据提问者反馈,SM-G350使用了BCM4330芯片,理论上支持mon模式。但实践发现,Android系统的限制可能导致其无法直接启用该模式。

  1. 尝试其他工具: 在ADB shell下运行 sudo tcpdump -i wlan0 会显示类似“Operation not possible due to RF-kill”的错误信息。

  2. 分析原因:

  3. 根据问题讨论中的信息,芯片组不支持mon模式是一个主要原因。
  4. 可以进一步尝试使用修改后的内核或者其他第三方的方法,但此方案复杂且风险较大。具体步骤可能需要编译自己的内核或者寻找专门的固件。

  5. 参考现有解决方案:

  6. 针对Broadcom 4330芯片组,有人提供了编译内核和设置的教程:BCMON

  7. 总结:

  8. 虽然理论上BCM4330芯片组支持mon模式,但实际在安卓环境中启用该模式较为困难。
  9. 对于普通的Android智能机,使用更简单的应用或工具来处理日常抓包需求可能是个更好的选择。

通过详细理解设备的硬件与软件限制,并尝试各种可行性方案,可以探索最适合自己设备的方法。如果想要实现更复杂的网络抓包需求,则需要更深入的技术支持和开发工作。

正文完