用 Wireshark 嗅探 ESP32 通信数据,教你看懂“WiFi 的语言”

🕵️ 用 Wireshark 嗅探 ESP32 通信数据,教你看懂“WiFi 的语言”

很多做 ESP32 的工程师都会遇到一个瓶颈:

  • 代码看起来没问题
  • 日志也没有明显报错
  • WiFi 连接就是不稳定 / 偶尔失败 / 延迟巨大

这时候,继续“猜”已经没意义了。
真正工程级的调试手段只有一个:抓包,看数据在“空中”到底发生了什么。

今天这篇文章,手把手带你用Wireshark嗅探 ESP32 的通信数据,让你真正“听懂 WiFi 在说什么”。


一、为什么一定要学会抓 WiFi 包?

日志只能告诉你结果,而抓包能告诉你过程

通过 Wireshark,你可以直接看到:

  • ESP32 是否真的发出了 Probe / Auth / Assoc
  • WPA2 / WPA3 四次握手是否完整
  • DHCP 为什么失败
  • 是否存在大量重传(Retry)
  • ACK 丢失、信道拥塞、RTS/CTS 行为

一句话总结:

WiFi 调试,不看包就是盲人摸象。


二、抓 WiFi 包的前置条件(非常关键)

⚠️ 先说结论:
普通笔记本电脑,默认是抓不到 WiFi 空口数据的。

你需要满足以下条件之一:


✅ 方案一:支持 Monitor Mode 的无线网卡(最推荐)

  • USB WiFi 网卡

  • 芯片推荐:

    • RTL8812AU
    • RTL8821CU
    • Atheros AR9271

系统支持情况:

  • Linux:最好(原生支持监听模式)
  • Windows:需要特殊驱动
  • macOS:部分型号支持

✅ 方案二:ESP32 本身开启 Sniffer(进阶)

ESP32 可以工作在Promiscuous Mode,用于监听周围 WiFi 帧(适合分析环境,但抓不到加密数据内容)。


三、Wireshark 基础设置(一步到位)

1️⃣ 开启监听模式(Linux 示例)

iplinksetwlan0 down iw dev wlan0settypemonitoriplinksetwlan0 up

启动 Wireshark,选择wlan0接口。


2️⃣ 设置监听信道(否则什么都抓不到)

iw dev wlan0setchannel6

⚠️必须和 ESP32 所连 AP 的信道一致


四、先抓一个“完整的 ESP32 入网过程”

推荐测试流程:

  1. 关闭 ESP32
  2. 开始抓包
  3. 上电 ESP32
  4. 停止抓包

你会看到以下典型帧序列:


🔍 阶段 1:扫描(Discovery)

关键帧:

  • Beacon
  • Probe Request
  • Probe Response

Wireshark 过滤器:

wlan.fc.type_subtype == 0x08 # Beacon wlan.fc.type_subtype == 0x04 # Probe Request

你可以确认:

  • ESP32 是否在主动扫描
  • AP 是否正常回应

🔐 阶段 2:认证 & 关联

关键帧:

  • Authentication
  • Association Request / Response

过滤器:

wlan.fc.type_subtype == 0x0b # Auth wlan.fc.type_subtype == 0x00 # Assoc Req

如果卡在这里,通常是:

  • 加密模式不匹配
  • AP 不支持 ESP32 的能力集

🔑 阶段 3:WPA2/WPA3 四次握手

你会看到:

  • Message 1 / 2 / 3 / 4
  • Key Information 字段

过滤器:

eapol

重点观察:

  • 是否 4 条消息都齐全
  • 是否频繁重传
  • Message 3 丢失最常见

🌐 阶段 4:DHCP 获取 IP

典型序列:

DHCP Discover DHCP Offer DHCP Request DHCP ACK

过滤器:

bootp

如果你看到:

  • Discover 发出但没 Offer
    👉 路由器 DHCP 表满 / 忙

五、看懂 WiFi 帧的几个关键字段

1️⃣ RSSI(信号强度)

在 Radiotap Header 中:

  • -30 ~ -60 dBm:很好
  • -70 dBm:开始不稳定
  • < -80 dBm:必丢包

2️⃣ Retry 位(判断是否拥塞)

过滤重传帧:

wlan.fc.retry == 1

大量 Retry =
👉 信道拥塞 / 干扰严重 / ACK 丢失


3️⃣ Duration / NAV(虚拟占用)

Duration 值越大,说明信道被占用时间越长
在 IoT 密集场景中非常常见。


4️⃣ ACK 是否正常返回

ACK 帧过滤:

wlan.fc.type_subtype == 0x1d

无 ACK =
👉 数据可能白发了


六、抓包分析 ESP32 常见问题案例


❌ 案例 1:ESP32 偶尔连不上 WiFi

抓包现象:

  • Probe 正常
  • Auth 正常
  • Message 3 重发多次

结论:
👉 WPA2 四次握手中丢包
👉 信号弱 / 干扰


❌ 案例 2:已连 WiFi 但无 IP

抓包现象:

  • DHCP Discover 重复
  • 无 Offer

结论:
👉 DHCP 服务问题
👉 路由器连接数已满


❌ 案例 3:MQTT 延迟巨大

抓包现象:

  • TCP 重传多
  • Retry 位频繁
  • ACK 延迟

结论:
👉 CSMA/CA 退避严重
👉 2.4GHz 拥堵


七、ESP32 抓包调试黄金法则

✔ 先抓入网包
✔ 再抓业务包
✔ 用过滤器缩小范围
✔ 不要一上来就看 TCP
✔ 永远关注 Retry 和 RSSI


八、推荐 Wireshark 过滤器速查表

目的过滤器
Beaconwlan.fc.type_subtype == 0x08
Probewlan.fc.type_subtype == 0x04
Authwlan.fc.type_subtype == 0x0b
WPA 握手eapol
DHCPbootp
重传wlan.fc.retry == 1
ACKwlan.fc.type_subtype == 0x1d

九、总结:看懂 WiFi 的语言,你就赢了一半

一句工程真理送给你:

WiFi 问题的答案,不在代码里,而在数据包里。

当你真正学会用 Wireshark 看 ESP32 的通信行为:

  • 掉线不再是玄学
  • 连接失败有据可查
  • 网络优化有明确方向

这也是从“能写代码”到“能做产品”的分水岭。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1131448.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

题解:AT_iroha2019_day3_f 闇のカードゲーム

AT_iroha2019_day3_f 闇のカードゲーム 题目描述 桌上整齐地摆放着 NNN 张卡片&#xff08;NNN 为奇数&#xff09;&#xff0c;每张卡片上有一个正整数。卡片按整数从小到大排列&#xff0c;位于第 iii 张卡片上的整数为 aia_iai​。不同的卡片上不会有相同的整数。 すぬけ君和…

Day60 PythonStudy

浙大疏锦行 import torch import torch.nn as nn import torch.nn.functional as F import torchvision import torchvision.transforms as transforms from torch.utils.data import DataLoader import matplotlib.pyplot as plt import numpy as np# 设置随机种子保证可重复…

【机械臂】基于Sawyer机械臂的多目标 RRT 路径规划 + 轨迹跟踪控制+ 数据生成附matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

AI产品经理VS普通产品经理:AI思维才是核心竞争力,程序员必学技能

文章阐述了AI产品经理与普通产品经理的区别&#xff0c;强调AI思维比算法理解更重要。详细介绍了AI产业链结构&#xff08;基础层、技术层、应用层&#xff09;和AI产品经理四象限分类&#xff08;突破型、创新型、应用型、普及型&#xff09;&#xff0c;并提供能力提升建议。…

【Hadoop+Spark+python毕设】近8年软科中国大学排名数据可视化分析系统、计算机毕业设计、包括数据爬取、数据分析、数据可视化、实战教学

&#x1f393; 作者&#xff1a;计算机毕设小月哥 | 软件开发专家 &#x1f5a5;️ 简介&#xff1a;8年计算机软件程序开发经验。精通Java、Python、微信小程序、安卓、大数据、PHP、.NET|C#、Golang等技术栈。 &#x1f6e0;️ 专业服务 &#x1f6e0;️ 需求定制化开发源码提…

MySQL--》深入理解视图、存储过程与触发器的强大功能

目录 视图 检查选项 视图更新 存储过程 基本语法 变量操作 条件语句 游标使用 存储函数 触发器 视图 视图&#xff1a;(View)是一种虚拟存在的表&#xff0c;视图中的数据并不在数据库中实际存在&#xff0c;行和列数据来自视图的查询中使用的表&#xff0c;并且是在…

【法学专业论文写作模版】未成年人犯罪低龄化问题及对策研究

目 录 引言 一、案情介绍及案例分析 &#xff08;一&#xff09;案情介绍 &#xff08;二&#xff09;案例分析及问题的引出 1.非刑罚类措施对未成年人如何适用 2.刑事责任年龄下调是否有利于预防未成年犯罪 3.家庭教育扮演着什么角色 二、我国目前未成年人犯罪低龄化的…

计算机网络必看:信道的极限容量,408真题常考!

计算机网络必看&#xff1a;信道的极限容量&#xff0c;408真题常考&#xff01;在学习计算机网络时&#xff0c;你是否曾困惑&#xff1a;“为什么网速不能无限快&#xff1f;” “一个信道到底能传多快&#xff1f;”这些问题的答案&#xff0c;就藏在信道的极限容量这个核心…

AI大模型开发学习指南:助你实现90%就业率和年薪72w+_AI爆了!最高年薪72w!

文章介绍AI大模型开发课程的就业优势&#xff1a;就业率超90%&#xff0c;最高年薪72万&#xff0c;应届生均薪15k。课程通过3.5个月系统学习&#xff0c;结合6大阶段和12个实战项目&#xff0c;帮助学员掌握大模型开发核心技能&#xff0c;达到2年工作经验等效竞争力。AI行业人…

【无人机三维路径规划】基于鳄鱼伏击算法CAOA多无人机协同路径规划(自定义:无人机数量)附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

手机变+Linux+控制台?JuiceSSH+++cpolar远程连接让运维随时随地搞定

JuiceSSH 是安卓设备上的一款 SSH 工具&#xff0c;能通过 SSH/SCP 协议连接 Linux 服务器、虚拟机等设备&#xff0c;支持执行命令、传输文件&#xff0c;还有图形化界面和配置保存功能。它适合需要远程管理服务器的运维人员、开发者&#xff0c;以及家里有 NAS 等设备需要维护…

华为HCCDP-GaussDB工作级开发者题库(带详细解析)

同学们有考HCCDP-GaussDB工作级开发者的没&#xff1f;整理了一部分题库&#xff0c;需要的再学可以一起学习。完整的题库已经发布在“题主”小程序上了&#xff0c;可以自己去找一下。以下哪一项系统视图可用于定位单个session在特性级上的内存问题&#xff1f;A、SESSION_STA…

2026 GEO落地真相:SHEEP-GEO 98.7%续约率背后,12亿月活平台的优化实战报告

2026年GEO服务商评测&#xff1a;技术、效果与场景化选择指南据中国信通院《2026生成式AI商业应用白皮书》披露&#xff0c;2026年中国GEO&#xff08;生成式引擎优化&#xff09;市场规模将突破520亿元&#xff0c;同比增幅超210%。随着DeepSeek、豆包、Kimi、文心一言等主流A…

MySQL--》理解锁机制中的并发控制与优化策略

锁是计算机协调多个进程或线程并发访问某一资源的机制&#xff0c;在数据库中除了传统的计算机资源(CPU、RAM、I/O)的争用以外&#xff0c;数据也是一种供许多用户共享的资源&#xff0c;如何保证数据并发访问的一致性、有效性是所有数据库必须解决的一个问题&#xff0c;锁冲突…

LeetCode 2080 区间频率查询详解(哈希表 + 二分法)

深度解析&#xff1a;空间换时间的艺术 —— 从区间频率查询看哈希与二分 在处理大规模数据查询时&#xff0c;性能优化是核心。LeetCode 2080 题《区间内查询数字的频率》是一个绝佳的案例。本文将通过“哈希表预处理”与“二分查找”两大维度&#xff0c;带你领略现代 C 的解…

彻底搞懂浏览器原生录制:MediaRecorder API 深度解析

在现代 Web 开发中&#xff0c;音视频处理能力的边界正在不断扩展。过去依赖 Flash 或 Silverlight 插件才能实现的录制功能&#xff0c;如今已成为浏览器的原生能力。MediaRecorder API 正是这一变革的核心&#xff0c;它允许开发者直接在浏览器端捕获、编码并保存媒体流&…

AI大模型架构师必学指南:从知识储备到高薪前景,一篇收藏就够了!

AI大模型架构师是连接AI理论与产业落地的关键角色&#xff0c;需融合深度学习、分布式系统、软件工程等多领域知识。该岗位涵盖模型训练、部署与系统架构设计&#xff0c;要求兼具技术创新能力与行业洞察力。随着大模型在各行业广泛应用&#xff0c;人才需求激增&#xff0c;一…

IoT 场景中的 DHCP、ARP、ICMP 到底在干嘛?

&#x1f310; IoT 场景中的 DHCP、ARP、ICMP 到底在干嘛&#xff1f;连上 WiFi ≠ 能通信&#xff0c;真正的网络刚刚开始在 IoT 开发中&#xff0c;你一定见过这些现象&#xff1a; ESP32 显示 WiFi 已连接&#xff0c;但服务器连不上MQTT / HTTP 超时&#xff0c;但 TCP/IP …

MySql-9.1.0安装详细教程(保姆级)

目录 MySQL介绍&#xff1a; 一、下载 Mysql 安装文件 二、Mysql 安装教程 1.下载完成后进入解压&#xff0c;注意不要放在一个非中文路径下的文件夹下面否则后面会报错。我在此处解压放在了D盘MySQL目录下。 2.解压后的文件应该没有.ini文件。因此&#xff0c;需要创建in…

AI产品经理转型与大模型学习路线图,附赠全套学习资源_月薪3W的AI产品经理学习路线

文章提供了AI产品经理和大模型工程师的完整学习路线。AI产品经理路线包括基础知识、专业技能和软技能三大阶段&#xff0c;涵盖AI技术、产品管理等核心能力。大模型学习路线包括系统设计、提示词工程、平台应用开发等七个阶段&#xff0c;并提供相关学习资源。文章强调理论与实…