蓝牙的信息安全机制及密钥算法改进蓝牙作为一种新兴的短距离无线通信技术已经在各个领域得到广泛应用,它提供低成本、低功耗、近距离的无线通信,构成固定与移动设备通信环境中的个人网络,使得近距离内各种信息设备能够实现无缝资源共享。
由于蓝牙通信标准是以无线电波作为媒介,第三方可能轻易截获信息,所以蓝牙技术必须采取一定的安全保护机制,尤其在电子交易应用时。
为了提供使用的安全性和信息的可信度,系统必须在应用层和链路层提供安全措施。
本文重点讨论了蓝牙信息安全机制的构成原理及相关算法,并指出其在安全性方面存在的不足与问题。
因为对于大多数需要将保密放在首位来考虑的应用来说,蓝牙现行标准所提供的数据安全性是不够的。
蓝牙现行规范采用的128位密钥长度的序列的加密在某些情况下可以被破解。
本文同时提出了一种蓝牙安全机制的改进方案,即采用DES加密体制构建强健的加钥算法,能够在计算上证明此加密算法是安全可靠的。
1蓝牙的安全机制
蓝牙采取的安全机制适用于对等通信情况,即双方以相同方式实现认证与加密规程。
链路层使用4个实体提供安全性:一个公开的蓝牙设备地址,长度为48bit;认证密钥,长度为128bit;加密密钥,长度为8~128bit;随机数,长度为128bit。
以下重点讨论蓝牙安全机制的组成及相关算法。
1、1随机数发生器
随机数发生器在蓝牙标准中有重要应用,例如在生成认证密钥和加密密钥中以及查询-应答方案中等。
产生随机数的理想方法是使用具有随机物理特性的真实随机数发生器,例如某些电子器件的热噪声等,但是在实际应用中通常利用基于软件实现的伪随机数发生器。
蓝牙系统对于随机数的要求是“随机生成”和“非重复性”。
“随机生成”是指不可能以明显大于零的概率(对于长度为L位的蓝牙加密密钥,概率大于1/2L)估计出随机数值。
目前在众多类型的伪随机数发生器中,线性同余发生器(LinearCongruentialGenerator)被最广泛地研究与使用。
其表达式为:
Xn1=αXnc(modm)n≥0。
式中α和c为常量,m为模数,均为正整数。
αXnc对m作模运算后得到Xn1。
开始时以某种方式给出一个种子数X0;然后使用前一个随机整数Xn生成下一个随机整数Xn1,由此产生整数随机数列{Xn}。
1、2密钥管理
蓝牙单元密钥长度不能由单元制造者预置,不能由用户设置。
蓝牙基带标准规定不接收由高层软件给出的加密密钥以防止使用者完全控制密钥长度。
1、2、1密钥类型
链路密钥是一个128位随机数,为通信双方或多方共享的临时性或半永久性密钥。
半永久性链路密钥可以用于共享链路单元之间的几个相继认证过程中。
临时密钥的典型应用是:在点对多点通信情况下,同一信息需要安全地发往多个接收端,这时采用主单元密钥取代当前链路密钥。
蓝牙标准定义了四种链路密钥:①联合密钥kAB;②单元密钥kA;③临时密钥kmoster;④初始化密钥kinit。
此外还定义了加密密钥kc,由当前链路密钥生成。
对蓝牙单元来说,单元密钥kA在单元A中生成,依赖于该单元,很少改变。
联合密钥kAB。
由单元
A、B方共同生成。
临时密钥kmoster仅在当前会话中使用,也称主单元密钥。
初始化密钥kinit是蓝牙初始化过程中使用的链路密钥。
该密钥由一个随机数、一个通常为进制的PIN码以及发起单元的蓝牙设备地址BD_ADDR生成。
PIN码可由用户选择也可以是随蓝牙一起提供的固定数。
目前大多数应用中PIN码为4位的10进制数,无法提供较高的安全性。
蓝牙基带标准要求PIN码长度为1~16位,因此建议尽量使用较长的PIN码以增强安全性。
1、2、2密钥生成与初始化
每一对要实现认证与加密的蓝牙单元都要执行初始化过程,其过程由以下几部分组成:
(1)生成初始化密钥kinit:为初始化过程中临时使用的链路密钥。
该密钥由E22算法及相关参数生成,其生成原理图见图1。
E22输出的128位初始化密钥
kinit用于链路密钥的交换分配过程。
如果申请者与证实者没有交换过链路密钥,则kinit用于认证过程,否则不再使用。
该过程必须保证能够抵御一定的攻击,例如攻击者使用大量的假蓝牙地址BD_ADDR来测试大量PIN等,如果设备地址固定则每次测试PIN码等待间隔应按指数增加。
(2)认证:如果两个单元没有发生过通信联系,则使用初始化密钥作为链路密钥。
每次执行认证规程,均发布新随机参数AU_RANDA。
在相互认证中,首先在一个方向执行认证规程,成功后再反向执行认证。
认证成功将得到一个辅助参数ACo,即认证加密偏移量。
它将用于生成加密密钥。
(3)生成单元密钥:单元密钥在蓝牙单元首次运行时生成,根据E21算法生成并几乎不改变。
初始化时,通信双方通常选用一个内存容量较少的单元中的密钥作为链路密钥。
图3
(4)生成联合密钥:联合密钥是分别在A单元与B单元中生成的两个数字的组合。
生成过程是:每个单元生成随机数Lk_RANDA与Lk_RANDB,采用E21算法与各自的随机数、蓝牙地址分别生成另一个随机数Lk_kA与Lk_kB,并通过其他操作后两个单元得出联合密钥。
然后开始互相认证过程以确认交互过程成功。
联合密钥交换分配成功后将放弃使用原链路密钥。
(5)生成加密密钥:加密密钥kc根据E3算法,由当前链。