新起点
A5/1
2021-01-20 22:35:42

A5/1是用于在GSM标准中提供行动通信保密性的流密码,它是指定用于GSM的七个加密算法之一。A5/1的设计最初没有对外公开,但由于泄漏和逆向工程而广为人知。已经确定了A5/1中存在许多严重缺陷。

A5/1在欧洲和美国使用。A5/2为A5/1削弱过的版本,用于出口到某些地区。A5/1是在1987年开发的,当时尚未考虑在欧洲以外使用GSM,而A5/2是在1989年开发的。尽管设计最初都是保密的,但总体设计在1994年被泄露。该算法完全由Marc Briceno于1999年从GSM电话利用反向工程取得。在2000年时,大约1.3亿个GSM客户端依赖A5/1来保护其语音通信的机密性;到2014年,这一数字增加为72亿。

安全研究人员Ross Anderson在1994年报导说:“在1980年代中期,北约讯号情报机构之间就GSM的加密是否应该拥有较高的安全性,有着激烈的争论。德国方面认为应该如此,因为的德国边界有很长一部分与华沙公约组织接壤,但其他北约成员国没有这个状况,目前采用的算法是法国设计。”

A5/2是用于出口,相对于A5/1比较弱。它是指定用于用于GSM的七种A5加密算法之一。

该密码基于具有不规则时钟的四个线性反馈移位寄存器和非线性组合器的组合。

1999年,Ian Goldberg和David A. Wagner在发布A5/2的同一个月中对其进行了加密分析,结果表明该A5/2非常脆弱,以至于低端设备都可能会实时地破解它。

自2006年7月1日起,GSMA(GSM协会)强制要求GSM移动电话不再支持A5/2密码,这是因为它的弱点以及3GPP协会认为A5/1是强制性的。2007年7月,3GPP批准了一项更改请求,以禁止在任何新手机中使用A5/2。如果网络不支持电话所实现的A5/1或任何其他A5算法时,则可以使用未加密的连接。

GSM传输使用突发脉冲序列(Bursts)。一个典型的信道在一个方向上,每4.615毫秒发送一个突发脉冲(帧),每一帧包含114个可用于信息的位元。A5/1用于为每个帧产生密钥流的114位序列,该序列在调制之前与114位进行异或 。使用64位密钥和公开的22位帧号初始化A5/1。 早期的GSM使用Comp128v1生成密钥,将10个密钥位固定为零,因此有效密钥长度为54位。通过引入Comp128v3(可产生正确的64位密钥)可以纠正此缺陷。 当以GPRS/EDGE模式工作时,更高带宽的无线电调制允许更大的348位帧,然后在流密码模式下使用A5/3(KASUMI)来保持机密性。

A5/1基于具有不规则钟控的三个线性反馈移位寄存器 (LFSR)的组合。 三个移位寄存器的指定如下:

最低有效位的索引为0。

钟控会使用择多原则来决定是否对寄存器作移位操作。每个寄存器都有一个相关的钟控位。在每个周期,检查三个寄存器的钟控位,并确定多数位(0或者1)。如果钟控位与多数位一致,则对寄存器作移位操作。因此,在每个步骤中至少要对两个或三个寄存器进行移位,并且每个寄存器移位的概率是3/4。

比如,三个寄存器的钟控位为分别为0、0、1。此时0为多数位,钟控便会移位钟控位为0的第一和二个寄存器,而第三个寄存器维持不变。

最初,寄存器每一位设置为零。然后在64个周期中,根据以下方案混合64位密钥:在周期 0 i < 64 {\displaystyle 0\leq {i}<64} ,第 i {\displaystyle {i}} 位使用异或将密钥位添加到每个寄存器的最低有效位—

R = R K . {\displaystyle R=R\oplus K.}

然后将寄存器移位。

接着在用同样的方案混合22位的帧号。然后,整个系统使用前述的钟控机制循环100个周期,并丢弃输出。完成此操作后,密码已准备好生成输出密钥流的两个114位序列,下行(从基地台接收到的讯号)使用前114位,上行(回传给基地台的讯号)使用后114位。

A5/1已经有许多公开破解,根据已披露的内部文档,美国国家安全局(NSA)能够对A5/1消息进行例行解密。

某些攻击需要昂贵的预处理阶段,在此阶段之后几分钟或几秒钟即可破解密码。早期发现的漏洞只能在已知明文的前提下利用,并且是被动攻击。2003年,发现了更严重的漏洞,可以在唯密文的前提下利用,或采用主动攻击。在2006年,Elad Barkan、Eli Biham和Nathan Keller展示了针对A5/1, A5/3甚至是GPRS的攻击,攻击者可以窃听GSM手机讯号,实时解密或保存讯息,以在未来任何时间解密。

根据Jan Arild Audestad教授的说法,在1982年开始的标准化过程中,最初提出A5/1的密钥长度为128位。当时,预计128位的安全性足以满足为来十五年的需求。现在的研究人员相信,在量子计算出现之前,128位实际上仍然是安全的。Audestad、Peter van der Arend和Thomas Haug表示英国坚持使用较弱的加密,Haug表示英国代表告诉他这是安全的。为了让英国的特勤人员更容易窃听,英国建议使用48位的密钥长度,而西德则希望使用安全性更高的加密的来防止东德间谍活动。最后折衷方案是54位的密钥长度。

1994年, Ross Anderson提出了对A5/1的首次攻击。安德森的基本思想是猜测寄存器R1和R2的完整内容以及寄存器R3的一半。 这样,就可以确定所有三个寄存器的时钟,并且可以计算R3的后一半。

在1997年,Jovan Golic提出了一种基于求解线性方程组的攻击,该方法具有 2 40.16 {\displaystyle 2^{40.16}} 的时间复杂度下破解(单位表示为所需线性方程组解的个数)。

在2000年, Alex Biryukov、Adi Shamir和David Wagner表明,可以基于时间—内存权衡攻击对A5/1进行实时破密,这是基于Jovan Golic的早期工作。权衡取舍允许攻击者利用长度为两分钟的已知明文,在一秒钟内分析出密钥,或著利用一秒钟的已知明文在数分钟内分析出密钥,但是攻击者必须首先完成一个昂贵的预处理程序,该阶段需要 2 48 {\displaystyle 2^{48}} 步来计算300GB的数据。在预处理,数据需求,攻击时间和内存复杂度之间可能要进行一些折衷。

同年, Eli Biham和Orr Dunkelman公开了另一个对A5/1的攻击,通过A5/1钟控给出 2 20.8 {\displaystyle 2^{20.8}} 位的已知明文,其总工作复杂度为 2 39.91 {\displaystyle 2^{39.91}} 。在 2 38 {\displaystyle 2^{38}} 的预计算阶段之后,此攻击需要共需要32GB的内存。

Ekdahl和Johansson发表了有关初始化过程的攻击,该攻击可通过两到五分钟的已知明文在几分钟内破解A5/1。此攻击不需要预处理阶段。2004年,包含Maximov的几名研究人员将该结果改进为需要“少于一分钟的计算时间和几秒钟的已知明文”的攻击。 Elad Barkan和Eli Biham在2005年进一步改善了这一攻击。

在2003年,Barkan 等人。发表了一些有关GSM加密的攻击,是首次发现主动攻击。可以说服GSM手机短暂使用弱得多的A5/2密码。在使用同样的密钥下,相比于比较强健的A5/1,A5/2更容易被攻破。在针对A5/1的第二次攻击中概述,唯密文的前提下可以使用时间—内存权衡攻击,这需要大量的预计算。

2006年, Elad Barkan、Eli Biham和Nathan Keller出版了他们2003年论文的完整版本,其中包括针对A5/X密码的攻击。 作者声称:

我们将介绍针对GSM加密通信非常实用的唯密文攻击,以及对GSM协议的各种主动攻击。这些攻击甚至能破坏使用所谓“牢不可破”加密的GSM网络。我们首先说到对A5/2的唯密文攻击,该攻击只需要几十毫秒的加密手机通讯,利用个人电脑在数秒钟即可分析出正确的密钥。我们将此攻击扩展为对A5/1的(更复杂的)唯密文攻击。我们接着描述针对使用了A5/1,A5/3的网络协议,或甚至是GPRS协议的(主动)攻击。这些攻击利用了GSM协议中的缺陷,并作用在使用诸如A5/2等弱较弱密码算法的手机上。我们强调这些攻击是针对协议的,所以只要手机使用了较弱的密码算法就适用,例如,它们还适用于使用A5/1的密码分析来攻击使用A5/3的网络。不像以前的GSM攻击需要不切实际的信息,例如长时间的已知明文,我们的攻击非常实用,不需要任何已知明文。此外,我们描述了如何强化攻击的容错性。我们的攻击使攻击者可以在窃听的同时解密对话,或者留存在未来的任何时间解密。

2007年,波鸿鲁尔大学和基尔大学开始了一个研究项目,以开发基于FPGA的大规模并行加密加速器COPACOBANA。COPACOBANA是第一个使用快速时间—内存权衡技术的商业解决方案,可用于攻击使用A5/1、A5/2算法的GSM语音加密,以及资料加密标准(DES)。 它还可以在无需预先计算大型彩虹表的情况下,对GSM进行暴力破解。

2008年, “The Hackers Choice”发起了一个项目,旨在对A5/1进行实用的攻击。攻击需要构建大约3TB的彩虹表。通过姊妹计划中的扫描算法,该小组希望能够在大约3-5分钟内,从任何使用A5/1加密的GSM通联记录,或著SMS简讯中分析出加密密钥,从而可以听取通联记录以及清楚的阅读简讯。但是这些彩虹表没有公开。

密码学家Karsten Nohl和SaschaKrißler在2009年黑帽安全会议上发表了一个类似的A5/1破解项目。通过Nvidia图形处理器通用计算和P2P分布式计算体系,创建了彩虹表。从2009年9月中旬开始,该项目运行了12个Nvidia GeForce GTX 260的运算量。根据作者的说法,此攻击可用于密钥大小最大为64位的任何加密算法。

Chris Paget和Karsten Nohl在2009年12月发布了针对A5/1的“A5/1破解计划攻击表(A5/1 Cracking Project attack tables)”。这些表结合了压缩技术,包括彩虹表和特征点链(distinguished point chains)。这些攻击表的各部分加起来只有1.7TB。攻击表在三个月内使用40个分布式的CUDA节点计算出来,然后由社区成员Farid Nasiri上传到BitTorrent和Google云端硬盘上。最近,该项目宣布改用速度更快的ATI Evergreen代码,并更改了表的格式。Frank A. Stevenson宣布使用ATI生成的表破解A5/1。

爱德华·斯诺登在2013年泄露的文件指出,NSA“可以处理A5/1的加密”。

相关:

  • 流密码
  • 网站公告: