mirror of
https://github.com/78/xiaozhi-esp32.git
synced 2026-01-14 01:07:30 +08:00
2.2 KiB
2.2 KiB
BluFi 配网(集成 esp-wifi-connect)
本文档说明如何在小智固件中启用和使用 BluFi(BLE Wi‑Fi 配网),并结合项目内置的 esp-wifi-connect 组件完成 Wi‑Fi 连接与存储。官方
BluFi
协议说明请参考 Espressif 文档。
前置条件
-
需要支持 BLE 的芯片与固件配置。
-
在
idf.py menuconfig中启用WiFi Configuration Method -> Esp Blufi(CONFIG_USE_ESP_BLUFI_WIFI_PROVISIONING=y)。如果只想用 BluFi,可关闭同一菜单下的 Hotspot/Acoustic 选项。 -
保持默认的 NVS 与事件循环初始化(项目的
app_main已处理)。 -
CONFIG_BT_BLUEDROID_ENABLED、CONFIG_BT_NIMBLE_ENABLED这两个宏应二选一,不能同时启用。
工作流程
- 手机端通过 BluFi(如官方 EspBlufi App 或自研客户端)连接设备,发送 Wi‑Fi SSID/密码。
- 设备侧在
ESP_BLUFI_EVENT_REQ_CONNECT_TO_AP中将凭据写入SsidManager(存储到 NVS,属于esp-wifi-connect组件)。 - 随后启动
WifiStation扫描并连接;状态通过 BluFi 返回。 - 配网成功后设备会自动连接新 Wi‑Fi;失败则返回失败状态。
使用步骤
- 配置:在 menuconfig 开启
Esp Blufi。编译并烧录固件。 - 触发配网:设备首次启动且没有已保存的 Wi‑Fi 时会自动进入配网。
- 手机端操作:打开 EspBlufi App(或其他 BluFi 客户端),搜索并连接设备,可以选择是否加密,按提示输入 Wi‑Fi SSID/密码并发送。
- 观察结果:
- 成功:BluFi 报告连接成功,设备自动连接 Wi‑Fi。
- 失败:BluFi 返回失败状态,可重新发送或检查路由器。
注意事项
- BluFi 与 Hotspot/声波配网可以同时编译,但会同时启动,增加内存占用。建议在 menuconfig 中只保留一种方式。
- 若多次测试,建议清除或覆盖存储的 SSID(
wifi命名空间),避免旧配置干扰。 - 如果使用自定义 BluFi 客户端,需遵循官方协议帧格式,参考上文官方文档链接。
- 官方文档中已提供EspBlufi APP下载地址