Micro:Bit BLE特征值通知接收问题及UUID格式错误求助
解决Micro:Bit BLE GATT通知接收的问题
首先,先搞定你遇到的UUID格式错误:你用的6E400003B5A3F393E0A9E50E24DCCA9E是Micro:Bit UART服务的通知特征UUID,但多数BLE开发库要求128位UUID必须带连字符分隔,正确格式应该是6E400003-B5A3-F393-E0A9-E50E24DCCA9E(注意分组是8-4-4-4-12个字符)。部分库也接受大写形式,或是不带连字符但转成字节数组的格式,但带连字符的标准格式兼容性最好。
接下来,我帮你梳理并修正整个操作流程,确保能正确接收特征值变化的通知:
正确的完整操作步骤
- 检查系统BLE兼容性:确认你的主机(电脑/手机)支持BLE 4.0+,且对应开发库(比如Python的bleak、Web Bluetooth API)能正常调用系统蓝牙接口
- 启用蓝牙:通过系统设置或代码调用开启主机蓝牙(比如Python的bleak库会自动检测蓝牙状态,若未开启可能抛出异常,需要手动或代码触发开启)
- 配对/连接Micro:Bit设备:
- 确保Micro:Bit已开启BLE广播(默认UART服务是开启的,或是你用MakeCode/Scratch烧录了开启BLE的程序)
- 通过设备名称(默认是
BBC micro:bit [XXXX])或MAC地址连接,避免多设备混淆
- 监听连接状态变化:
- 连接成功后绑定状态回调,处理连接断开重连、连接失败等异常情况
- 定位目标服务与特征:
- 先找到Micro:Bit的UART服务,UUID是
6E400001-B5A3-F393-E0A9-E50E24DCCA9E(也可用短UUID0xFFE0,但128位UUID更准确) - 在该服务下找到通知特征,就是你之前用到的
6E400003-B5A3-F393-E0A9-E50E24DCCA9E(对应UART的RX特征,Micro:Bit向主机发送数据时会触发通知)
- 启用GATT通知:
- 必须调用库的
start_notify类方法(不同库名称可能有差异),传入特征UUID和回调函数,这样特征值变化时才会主动触发通知
- 处理特征值更新:
- 在回调函数里解析收到的字节数据(Micro:Bit通常发送ASCII字符串,转成字符串即可读取)
示例代码(Python + Bleak库)
import asyncio from bleak import BleakClient, BleakScanner # Micro:Bit UART服务和通知特征的标准UUID UART_SERVICE_UUID = "6E400001-B5A3-F393-E0A9-E50E24DCCA9E" UART_NOTIFY_CHAR_UUID = "6E400003-B5A3-F393-E0A9-E50E24DCCA9E" # 特征值更新的回调函数 def notification_handler(sender, data): print(f"收到Micro:Bit数据: {data.decode('utf-8').strip()}") async def main(): # 扫描并找到Micro:Bit设备 devices = await BleakScanner.discover() microbit_device = None for d in devices: if "BBC micro:bit" in d.name: microbit_device = d break if not microbit_device: print("未找到Micro:Bit设备,请检查蓝牙是否开启或设备是否在广播") return # 连接设备 async with BleakClient(microbit_device) as client: print(f"已连接设备: {microbit_device.name}") # 设置断开连接回调 def on_disconnect(client): print("设备已断开连接") client.set_disconnected_callback(on_disconnect) # 启用GATT通知 await client.start_notify(UART_NOTIFY_CHAR_UUID, notification_handler) print("已启用GATT通知,等待数据...") # 保持连接,持续监听通知 while client.is_connected: await asyncio.sleep(1) if __name__ == "__main__": asyncio.run(main())
常见问题排查
- UUID格式错误:再次确认UUID的连字符位置,128位UUID必须是8-4-4-4-12的分组格式,多数库不接受无分隔符的长字符串
- 无法收到通知:
- 确认Micro:Bit的程序确实在向该特征写入数据(比如用MakeCode的UART发送块)
- 确保已经调用了
start_notify方法,没有这一步主机不会收到任何特征更新通知 - 检查连接稳定性,若频繁断开可调整设备距离或重启蓝牙
- 连接失败:确保Micro:Bit没有被其他设备占用,或是已配对但未连接,尝试重启Micro:Bit的蓝牙
内容的提问来源于stack exchange,提问作者Lechucico




