设置你的本地设备作为外设的最佳实践
和许多中央端事务一样,这个Core Bluetooth框架给你控制实现外设角色的大部分。这个章节提供了指导方针和最佳实践,以一种负责任的方式利用这种控制的水平。
广播的注意事项
广播外设数据对于设置你的本地设备来实现外设角色是很重要的。下面的部分有助于以一个恰当的方式做这些。
考虑广播数据的限制
你广播你的外设数据通过CBPeripheralManager
类的startAdvertising:
方法传递一个广播数据的字典,正如Advertising Your Services所描述。当你创建了一个广播字典,记住,你可以广播时有什么限制以及限制多少。
虽然在通常情况下广播包可以携带关于外设的多种信息,你只能够广播你的设备本地名和你想要广播的一些服务UUIDs。也就是说,当你创建你的广播字典时,你只能指定这两个键:CBAdvertisementDataLocalNameKey
和CBAdvertisementDataServiceUUIDsKey
。如果你指定其它的键会接收到一个错误。
当广播数据时你使用的空间也是有限的。当你的应用程序处于前台,最多可以使用28个字节的空间在初始广播数据中,为了提供给两个支持的广播数据键。如果这个空间用完了,有一个在扫描响应时只能用于本地名称的额外的10字节的空间,任何服务的UUIDs都不适用于分配到这个特殊的溢出区域;它们只能被发现通过一个iOS设备明确地扫描它们。当你的应用程序处于后台时,在这个溢出区域本地名称不会被广播,所有的服务UUIDs在这里。
注意:这些空间大小不包括任何新数据类型要求的头部信息的两个字节。广播和回应数据的准确的格式在蓝牙4.0规范中有定义。
为了帮助你保持在这些空间约束内,限制你广播给这些标识你的主要服务的服务UUIDs。
只有在你需要的时候才广播数据
自从广播外设数据使用你的本地设备的无线(和你设备的电池),当你想要其它的设备连接你的设备时才广播。一旦连接上,这些设备可以直接探索并于外设数据交互,不需要其它的任何广播包。因此,为了最小化无线的使用,增加应用程序的性能,保留你的设备的电量,当它不再需要时停止广播来促进任何预期的蓝牙低功耗事务。为了在你的本地外设上停止广播,简单地调用CBPeripheralManager
类的stopAdvertising
方法,就像:
[myPeripheralManager stopAdvertising];
让用户决定什么时候广播
知道什么时候可以广播往往是用户可以知道的东西。例如,当你知道附近没有任何其它的蓝牙低功耗设备时在你的设备上广播服务是没有意义的。你的应用程序往往也没有意识附近有什么其它的设备,在你的应用程序上为用户提供用户交互界面来让用户决定什么时候去广播。
配置你的特征
当你创建一个可变的特征,你要设置它的属性,值,和权限。这些设置决定着怎样与访问和与特征值交互的中央连接。虽然你可能要决定配置你的特征的属性和权限在你的应用程序需求的基础上。下面部分提供了一些指导方针在你需要执行下面两个任务时:
- 允许连接的中央来订阅你的特征
- 保护敏感的特征值被配对中央访问
配置你的特征来支持通知
正如在Subscribe to Characteristic Values That Change Often中描述,要求中央订阅经常改变的特征值(一个远程外设的服务的)。当可能时,通过允许连接外设来订阅你的特征值来鼓励这个实践。
当你创建了一个可变的特征,配置它来支持订阅,通过使用CBCharacteristicPropertyNotify
常量来设置特征属性,就像:
myCharacteristic = [[CBMutableCharacteristic alloc] initWithType:myCharacteristicUUID properties:CBCharacteristicPropertyRead | CBCharacteristicPropertyNotify value:nil permission:CBAttributePermissionReadable];
在这个例子中,特征值是可读的,并能够通过连接的中央订阅。
需要一个配对的连接来访问敏感数据
根据一些使用情况,你可能想要发送一个有一个或多个特征值需要很安全的服务。例如,想象你想要发送一个社交媒体配置服务。这个服务可能有特征值代表成员的个人信息,比如姓,名,和邮件地址。很可能,你想要允许只有信任的设备来获取一个成员的邮件地址。
你可以通过设置恰当的特征属性和权限来保证只有信任的设备能够访问敏感的特征值。继续这个例子,为了允许只有信任的设备获取一个成员的邮件地址,设置特征的属性和权限,就像:
emailCharacteristic = [[CBMutableCharacteristic alloc] initWithType:emailCharacteristicUUID properties:CBCharacteristicPropertyRead | CBCharacteristicPropertyNotifyEncryptionRequired value:nil permissions:CBAttributePermissionsReadEncryptionRequired];
在这个例子中,特征被配置成允许只有信任的设备能够读和订阅它的值。当一个连接远程中央尝试读取或订阅这个特征值时,Core Bluetooth会尝试配对你的本地外设与该中央来创建一个安全的连接。
例如,如果中央和外设都是iOS设备,两个设备接收到一个提醒,表明另一个设备想要配对。中央设备的提醒包含一个密码你必须填入外围设备的文本框中来完成配对步骤。
在完成配对步骤后,外设会认为该配对的中央是可信任的设备,并允许该中央访问它的加密的特征值。
--翻译的文档地址:Best Practices for Setting Up Your Local Device as a Peripheral