最近在做微信小程序的蓝牙功能,连接的设备是MPOS,但是收发数据发现,如果手机端接收的数据超过20byte就无法有效收到。
查询了很多资料,也尝试了抓报蓝牙的btsnoop_hci.log来进行分析,发现并没有收到notify的数据,说明手机端没有收到。
网上大多数的结论是:BLE做了收发的data最大数据限制,单个数据包的默认系统最大长度是23byte(字节),超过了就会出问题【20byte的Data数据 + 3byte的蓝牙 Header】。之前微信也没有做相关的处理,其实Android本身如果做BLE连接的话是可以修改单个数据包的最大长度值的,也就是MTU值。
这个问题在IOS上是不存在的。
有两种解决办法:
1.蓝牙模块的BLE底层修改,厂商更改发包逻辑,每次最大发包的长度不超过23byte就行。【这种情况一般比较难】
2.微信在2.11.0的lib库支持了修改BLEMTU值来更改系统的默认值,代码如下:
const mtu = 512;
wx.setBLEMTU({
deviceId: that.data.deviceId,
mtu,
success:(res)=>{
console.log("setBLEMTU success>>", res)
},
fail:(res)=>{
console.log("setBLEMTU fail>>", res)
}
}),
支持设置的范围是(20,512);
调试发现,我的小米9手机如果设置超过180byte就会报错,
但是失败了貌似还是有效,初步判断如果设置超过了系统的最大值,默认使用系统支持的最大值?这个无法判断,但是确认更改有效,即使设置显示失败。后续多测试几种类型的android手机再做结论。
设置了该值之后,就可以正常收发了。我的蓝牙设备单个包最大数据长度为129byte,超过了就会分包,所以在实际开发的过程中,只要满足自己蓝牙设备发送单个包的最大长度就可以实现接收数据了。
发送分包类似,对于太大的数据,最好做分包发送。