iOS上的BLE广告和CBAdvertisementDataLocalNameKey大小

问题描述

在iOS上使用蓝牙低能耗广告时,广告为CBAdvertisementDataLocalNameKey的数据的最大大小是多少?在进行一些测试时,我将以下代码用于BLE广告:

var manager: CBPeripheralManager!
//...
let customData = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"
manager.startAdvertising([CBAdvertisementDataServiceUUIDsKey:[serviceCBUUID],CBAdvertisementDataLocalNameKey: customData])

我注意到在检测到外围设备(func centralManager(_ central: CBCentralManager,didDiscover peripheral: CBPeripheral,advertisementData: [String : Any],rssi RSSI: NSNumber))时调用的委托方法的第二个设备上,我的自定义数据被剪切为以下字符串:“ 01234567”,因此它只有8个字节。 startAdvertising函数的文档中提到了有关 “对于支持的广告数据密钥的任何组合,初始广告数据中最多28个字节的空间” 。有人可以解释为什么在我的情况下只有8个字节吗?实际上,在iOS上,此CBAdvertisementDataLocalNameKey是否总是8个字节,还是可以更改此数字?如何计算将成功发送广告包的字节数(在我的情况下为8个字节)?在iOS上使用BLE时,有什么方法可以宣传8个字节以上的内容?同时发布的服务数量是否有限制?例如,是否可以同时发布10个不同的uuid,每个uuid包含8个字节,总共允许同时发布80个字节?

解决方法

与大多数BLE事物一样,这取决于。但通常来说,除非您进行了扩展广告,否则广告包的大小为31字节(有时可在更新的手机和更新的iOS版本上使用,更多信息请参见下文)。完整的广告区域是37个字节减去6个MAC必需字节。其中包括所有内容:发送的每件商品的长度,标签和价值(LTV)。

因此,首先要有标志,这是三个字节(长度,标签,值)。因此,现在我们记录在案的28个字节。

因此,您想发送一些服务UUD。我假设serviceCBUUID是128位临时UIUD,而不是16位分配的UUID。因此,这是一个2字节的标头(长度,包含128位服务UUID的完整列表),外加16字节的数据。

现在我们只有10个字节。

您的名字不能容纳10个字节,因此我假设它发送的是“本地名称缩短”标签,以及将要容纳的8个字节(包括一个长度字节)。

如果要发送更长的名称,则需要缩短有效载荷中的其他内容。

在您的情况下,您可能只想删除CBAdvertisementDataServiceUUIDsKey。如果有空位,Apple通常会为您解决。如果没有空间,则Apple有一个巧妙的专有技巧,可以将数据散列到溢出区域中。只要仅由其他Apple设备进行扫描,此方法就可以很好地工作,而且您无需花费广告宣传全面服务的UUID就能获得的收益。但是,如果您需要使用Apple设备以外的其他设备进行扫描,则无法使用。

如果您确实需要播发服务UUID,并且还希望为您的本地名称提供更多空间,那么您将需要buy an assigned UUID。这些价格为2500美元,是16位而不是128位,这将为您返回14个字节的本地名称。

关于您的问题“ 10个不同的uuid每个都有8个字节”,我不确定您从哪里得到这些数字。 BLE UUID是16个字节(128位)或2个(16位)。但是可以,如果您尝试播报10个16字节UUID,这些UUID将会溢出。 iOS可能会发布尽可能多的广告,然后将其余的哈希散列到溢出区域(如上所述)。服务UUID的完整列表在连接后仍然可用,即使它们没有被公布也是如此。

如果您有10个16位UUID,则将占用22个字节,这可以很方便地放入广告包中(没有本地名称)。要获取两个以上的16位UUID,您至少需要成为Bluetooth SIG的Associate Member。每年费用为7,500美元或35,000美元,具体取决于公司的规模。采用者(免费)只能以$ 2,500 /每人的价格注册其中的两个。

现在,如果这仅适用于运行iOS的较新版本(我相信为12+)的相当新的iPhone(我认为是8+),则存在扩展的广告,其允许多达124字节的有效负载。有关详细信息,请参阅WWDC 2019中的"What's New in Core Bluetooth"。扫描设备还需要支持扩展扫描才能工作。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...