任何网络设备而言,都会有自己独特的一个MAC地址,不然在设备量较大的情况下很可能造成通信的混乱。蓝牙是无线通信中使用非常广泛的技术,当然其蓝牙地址也是相当的重要的了。
种类划分
- public地址
- random地址
蓝牙地址长度,48bit,即6个byte。
该地址是固定的,厂商设定:
public addr和resolvable random addr和unresolvable random addr
Random地址其实又分为两种:
- Static地址
- Private地址
这种地址是在蓝牙设备上电初始化成功后,就不会再变化,而到关闭电源再重启,才会使用一个新的值。
这种是non resolvable的private地址,其值不能和public地址一样。对于这种地址,如果都没有办法解析出,不知道需要这类地址有什么作用?以后知道了再来补充吧。不过觉得可能是对Public地址的一个补充。
这种是resolvable的private地址,prand部分是随机生成的24bit数值,hash部分使用如下的方式生成:
hash = ah(IRK, prand)
ah是SMP部分的随机地址生成函数,IRK是密钥(Identity Resolving Key),先随机生成prand部分,然后用这个算法生成hash,然后将hash和prand部分填入上图中对应bit区域,就形成了resolvable private address(RPA)了。
因为上面这种地址是resolvable的,当然得有对应的地址解析的方法了,通过解密所获得对方的蓝牙地址,才可以进行某些通信,看来是BLE的新特性所提供安全性的一些手段了。
在拿到对方的resolvable private address(RPA)后,本地设备从RPA中取出prand部分,然后会根据上面hash的生成方式生成一个叫localhash的:
localHash = ah(IRK, prand)
然后将这个localHash和从RPA中取出的hash部分进行比较,如果相同,那么对方设备就被识别了。感觉这里的识别作用就是确定应当用哪个IRK和对方设备交互。对于这种random地址的方式,后面还得再看看,应当是比较新的特性。