蓝牙BLE开发
这个文章记录一下遇到的坑哈。。。
背景
业务场景:某个传感器设备所在的开发板(以下简称板子)只有USB接口,没有蓝牙接口,目前的方案是板子通过USB连接一个WINDOWS10的平板电脑(以下简称win平板),WINDOWS10平板以蓝牙的方式连接微信应用程序,实现数据的上报。
具体情况:win平板现在可以实现把数据从板子读取,然后存放到文件中,但是还没有实现文件到微信的数据传送。
需求:将数据从WIN平板发送到微信程序中。
分析
因为BLE节能和通用度高的原因,因此打算通过BLE的方式连接WIN平板与微信程序。这样就要求WIN平板要作为外围设备。先使用Java+Spring完成后台操作,(经过折腾后台签名验证,安全域名等)各种微信硬件平台API+JSAPI都搞定,开始搞设备与外围WIN平板的连接。。
微信硬件开发平台提供了AirSyncDebugger(ASD)可以用来检测微信蓝牙BLE广播数据(AirSync协议),来验证数据包是否正确。现在有意思的就来了。。。
方案
win7 + VS+ C++ : 找了半天貌似只支持经典蓝牙的编程方式,没有找到和BLE广播的相关API 。。。放弃(后来才知道win8之后才支持ble)
win10+VS+C++ :找了btnleapis.h与btnledef.h这两个头文件,这两个头文件的只提供了一些常量定义和把WIN平板作为中心设备的API 。。。 然后同样无法实现广播。。放弃
UWP+C#:方式,这种情况下,UWP的API是提供广播相关的API,窃喜,马上弄了一个DEMO,弄完之后点击Run的时候,提示让我安装windows mobile emulator。。。。我了个X。。。
换设备。。。。。。
iOS设备:查看了一下ios平台上有相关广播的API ,窃喜,继续试,用的objective-c语言,广播API接受一个参数,[self.peripheralManager startAdvertising:self.advertisement]; 后面的self.advertisment是一个NSDictionary类型参数,通过这个变量定义广播数据,这个字典KEY大概是有三种,CBAdvertisementDataServiceUUIDsKey,CBAdvertisementDataLocalNameKey和CBAdvertisementDataManufacturerKey,然后看github上例子一般只用了前两个参数,都没有最后一个CBAdvertisementDataManufacturerKey,既然都提供了这样一个KEY了,根据微信AirSync的描述0xFF+2bytes+MAC地址拼成,扔到CBAdvertisementDataManufacturerKey对应的Value里面不就万事大吉了吗。。。Airdebugger还是校验不通过说不含有MAC地址或者没以它结尾。。最后尝试了好几次。。发现广播参数有没有CBAdvertisementDataManufacturerKey这个KEY对应的Value广播出来的数据包通过AirDebugger分析完全一样,那个key广播的时候会被无视掉,只是用来ios当中心设备时读取厂商自定数据。。这TM就蛋疼了。。如果广播不出去那个数据就不遵循AirSync的要求。。所以我估计这也是一个死路[doge]。。
Andoird 5.1:Android平台在4.3开始支持设备作为中心设备去连接外设,4.1开始支持作为外围设备,提供相关的API,拿了一个huawei mate7 原来是emui3系统,刷到emui3.1正好兼容5.1 (找固件找了半天。妈的)。 然后连接MAC,通过Android Studio跑DEMO。。。那个设备获取bluetoothadverise为空,大概是设备太老不支持?(这个方案还没出结果,要换更新的设备在试)
。。。。。待续中。。。。。。。。。。。。。。。