尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

基于mac80211_hwsim搭建WiFi模拟测试环境(下)-- 环境搭建与测试

基于mac80211_hwsim搭建WiFi模拟测试环境(下)-- 环境搭建与测试
📅 发布时间:2026/6/26 22:27:45

基于mac80211_hwsim搭建WiFi模拟测试环境(下)-- 环境搭建与测试 | DD'Notes基于mac80211_hwsim搭建WiFi模拟测试环境(下)– 环境搭建与测试前言上篇 《基于mac80211_hwsim搭建WiFi模拟测试环境(上)– 前篇介绍》(https://notes.z-dd.online/2026/04/09/%E5%9F%BA%E4%BA%8Emac80211_hwsim%E6%90%AD%E5%BB%BAWiFi%E6%A8%A1%E6%8B%9F%E6%B5https://notes.z-dd.online/2026/04/20/%E5%9F%BA%E4%BA%8Emac80211_hwsim%E6%90%AD%E5%BB%BAWiFi%E6%A8%A1%E6%8B%9F%E6%B5%8B%E8%AF%95%E7%8E%AF%E5%A2%83%EF%BC%88%E4%B8%8B%EF%BC%89--%20%E7%8E%AF%E5%A2%83%E6%90%AD%E5%BB%BA%E4%B8%8E%E6%B5%8B%E8%AF%95/

基于mac80211_hwsim搭建WiFi模拟测试环境(下)– 环境搭建与测试
前言
上篇 《基于mac80211_hwsim搭建WiFi模拟测试环境(上)– 前篇介绍》(https://notes.z-dd.online/2026/04/09/%E5%9F%BA%E4%BA%8Emac80211_hwsim%E6%90%AD%E5%BB%BAWiFi%E6%A8%A1%E6%8B%9F%E6%B5%8B%E8%AF%95%E7%8E%AF%E5%A2%83%EF%BC%88%E4%B8%8A%EF%BC%89–%20%E5%89%8D%E7%AF%87%E4%BB%8B%E7%BB%8D/) 主要对其有些概念做了些简单介绍,这篇主要讲讲整个测试环境搭建及进行简单测试。

准备测试框架
获取项目源码:

BASH
git clone https://git.w1.fi/hostap.git
安装必要的依赖包:

BASH
sudo apt-get install -y build-essential git libpcap-dev libsqlite3-dev binutils-dev libnl-3-dev libnl-genl-3-dev libnl-route-3-dev libssl-dev libiberty-dev libdbus-1-dev iw bridge-utils python-crypto tshark
其他的报错时按需安装就行。

编译测试组件:
进入tests/hwsim目录,可以每个组件单独编译,如下:

BASH
cd ../../wpa_supplicant
cp ../tests/hwsim/example-wpa_supplicant.config .config
make clean
make
cd ../hostapd
cp ../tests/hwsim/example-hostapd.config .config
make clean
make hostapd hostapd_cli hlr_auc_gw
cd ../wlantest
make clean
make
也可以使用目录下现成的编译脚本./build.sh

wpaspy:
Python 脚本使用 wpaspy.py 来与 wpa_supplicant 控制接口进行交互,但 run-tests.py 测试脚本会将该(相对)路径添加到环境中,因此无需安装 wpaspy.py

准备内核
主要是启用mac80211_hwsim,检查配置CONFIG_MAC80211_HWSIM=m

其他相关配置
配置用户免密:

测试过程中的某些部分需要 root 权限。目前测试脚本通过 sudo 来获取这一权限。为了能够运行测试,你可能需要配置 sudo 并设置超时时间,避免密码验证很快过期。

直接允许所有用户免密:

BASH
sudo visudo
#在文件中添加以下行:
#允许所有用户免密执行所有命令
ALL ALL=(ALL) NOPASSWD: ALL
#或者,如果你只想允许特定用户(例如 testuser)免密,可以添加:
#testuser ALL=(ALL) NOPASSWD: ALL
运行测试
运行完整测试用例集的最简单方法是执行 tests/hwsim 目录下的 run-all.sh 脚本。
该脚本会调用 start.sh 来加载 mac80211_hwsim 内核模块,并启动 wpa_supplicant、hostapd 以及多种测试工具。
随后使用 run-tests.sh 执行所有已定义的测试用例,最后通过 stop.sh 停止相关程序并卸载内核模块。

run-all.sh 还支持在不同条件下运行同一套测试用例:

BASH
# run normal test cases
./run-all.sh

# run normal test cases under valgrind
./run-all.sh valgrind

# run normal test cases with Linux tracing
./run-all.sh trace

# run normal test cases with multi channel support (see details below)
./run-all.sh channels=<num of channels>
对于手动测试,可以使用 ./start.sh 来初始化接口和程序,并使用 run-tests.py 来执行一个或多个测试用例。通过命令行参数 -d(输出更详细的调试信息)和 -q(输出更简洁的信息)可以控制 run-tests.py 的输出详细程度。使用 -f <模块名>(指向 test_<模块名>.py 文件)可以指定运行某个文件中的所有测试用例。在命令行最后加上测试名称可以指定运行单个测试用例(例如:./run-tests.py ap_pmf_required)。

需要注意的是,部分测试要求驱动程序支持多信道并发操作才能运行。如果驱动程序不支持多信道,这些测试将被跳过。要启用多信道支持,需要通过参数将支持的信道数量传递给 run-all.sh 或 start.sh。

测试结果及日志


作者: Shell
链接: https://notes.z-dd.online/2026/04/20/%E5%9F%BA%E4%BA%8Emac80211_hwsim%E6%90%AD%E5%BB%BAWiFi%E6%A8%A1%E6%8B%9F%E6%B5%8B%E8%AF%95%E7%8E%AF%E5%A2%83%EF%BC%88%E4%B8%8B%EF%BC%89--%20%E7%8E%AF%E5%A2%83%E6%90%AD%E5%BB%BA%E4%B8%8E%E6%B5%8B%E8%AF%95/
来源: DD'Notes
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

。。。 。。。


更多请关注我的博客:https://notes.z-dd.online/

或我的:


相关新闻

  • ESP32智慧养殖盒开发:4G联网与GPS追踪实战
  • Windows热键冲突检测工具:Hotkey Detective的完整使用指南
  • Cesium 使用Shadertoy教程

最新新闻

  • Navicat Premium Mac无限试用终极指南:告别14天限制的完整解决方案
  • 华为MetaERP Oracle EBS 标准采购流程,对你描述的场景进行详细的分录和金额分析。基础数据计算表格项目 计算 金额PO数量 — 1,000单价(不含税) — 10不含税金
  • ncmdump:音乐格式解密专家,5分钟掌握NCM转换全流程
  • 钢铁牌号中字母的含义,收藏起来~
  • Vue KeepAlive 原理深度解析:从使用到底层实现
  • 番茄小说下载器:解决数字阅读三大痛点的终极方案

日新闻

  • 单节点跑业务稳如泰山 扩容高可用集群反而频繁卡死 复盘完整连接交互揪出深层根因
  • Boss直聘批量投递工具:5倍效率提升的求职价值重构指南
  • 3分钟解锁VLC点击暂停插件:让视频控制变得如此简单!

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号