飞利浦的MIFARE卡因为它的高安全性在市场上得到广泛应用,比方我们乘车用的公交卡,学校和企业食堂的饭卡等等.它每一个扇区有独立的密匙(6个字节的password),在通信过程中首先要验证密匙才干读写数据.它的关键技术在于密匙的验证採用三重加密的DES算法,(即:读写器与卡之间传送的密匙是通过随机数加密的),不象早期的EMID卡和atmel的T557卡都是明码传输,所以在開始一度觉得是最安全的卡。被广泛的当做电子钱包使用.

自从08年有人成功破解了M1卡,曾一度造成恐慌.2008年,互联网上发布了破解Mifare Classic IC芯片(即M1芯片)password的方法;德国研究员亨里克·普洛茨(HenrykPlotz)和弗吉尼亚大学计算机科学在读博士卡尔斯滕·诺尔(KarstenNoh1)成功地破解了恩智浦半导体的Mirare经典芯片的安全算法;德国Virginia大学和荷兰Radboud大学两个独立研究小组分别证实了Mi-fare芯片的易受攻击性,并发表了破解芯片加密算法的论文<<“Wirelessly
Pickpocketing a Mifare Classic Card”(无线窃取M1卡)>>以及演示了实际操作芯片的破解过程。

阐明了M1卡在报文产生奇偶位和所谓嵌套认证两个方面的漏洞;利用此漏洞,攻击者能够通过工具只研究该工具与M1卡之间通讯数据便能够成功破解该卡的全部密钥,从而克隆这张卡.

文章觉得:M1在产生奇偶校验位时将数据链路层和安全通信层本该分层处理的协议混为一谈,先校验后加密,而且反复使用了加密校验位的password。这是不符合安全原则的并确实可被利用。

1. MIFARE破解方法

1)  暴力破解

即使是暴力破解,也须要先得到确切的明文和相应的码流。

这大约要进行1536次认证过程,用时在一秒钟之内。只是还要进行离线暴力破解,预计在36分钟可完毕。可是须要专用的硬件设备。

2)  以读卡器的挑战值做变量

这里说的读卡器实际上指的是用来模拟读卡器的攻击工具。下个攻击亦如此。这样的攻击又可称选择密文攻击,想法用工具控制被攻击的卡每次在认证时产生同一挑战值,而读卡端则回应不同值。这样的攻击须要大约28500次的认证过程,用时约15分钟。然后计算密钥。用时约一分钟。

3)  卡的挑战值做变量

这样的攻击与攻击2类似。但须要使自己的工具的挑战值为常数,而令卡的挑战值数不断变化。

须要预制一个384 GB的状态表。要进行4096次认证。

大约用时2分钟。

4)  嵌套认证攻击

这样的攻击如果攻击者已知了至少一个扇区的密钥,他能够依据漏洞得到其他密钥的32位,然后对其他16位进行穷举攻击。仅仅需3次认证(时间能够忽略不计)。离线攻击计算时间约为一秒。

M1卡嵌套认证的漏洞使得攻击者在得知一个扇区的密钥后可较easy的再破解其他不论什么扇区的密钥从而做到对该卡的全面破解。这在曾经的攻击中并不easy做到。由于一个应用系统的读卡器不一定能产生其系统中全部卡的全部扇区的密钥,如果设计系统时就没有考虑使用全部扇区的话。

2. Mifare破解对公交卡系统造成的影响

现有国内公交卡普遍採用的基于PSAM/ISAM卡的密钥管理系统。通常採用的做法是使用一个Value Block作为钱包,KeyA负责消费,KeyB负责充值(包含消费)。KeyA的分散密钥放在PSAM中,KeyB的分散密钥放在ISAM中(假设採用充值联机则KeyB可联机获得)。PSAM和ISAM提供了密钥的外部存储方式,通过特定的分散算法得出M1的密钥。计算过程发生在终端或后台系统中。

而眼下破解机制直接对M1卡发生作用,全然绕过、无视了PSAM等安全机制。

相同,一卡一密通过採用不同卡片不同密钥的做法添加破解难度,但面对高效率的破解算法也形同虚设。必须重视的是。现有公交卡系统高度依赖密钥管理系统、一卡一密等安全机制,採用的数据结构基本是统一的、公开的状态,这就意味着一旦破解密钥就差点儿处于不设防状态,即使数据结构不公开也不能寄予希望。

公交卡系统尽管也採用了黑名单等系统审计监控机制,但与银行卡系统的黑名单机制存在很大的差别:公交卡採用脱机黑名单。容量受到终端设备的限制,并且属于滞后处理(通常生效和处理周期不小于T+1天);银行卡採用联机黑名单,容量基本不受限制,并且属于实时处理(即时生效和处理)。

3. MIFARE卡系统可能面临的攻击分析

MIFARE卡被破解问题的严重性是不容置疑的,首先,Crypto1攻击的源码已经公开公布(http://code.google.com/p/crapto1/),属于开源项目,可随意从网上免费下载;其次,配套的几款读卡器(ProxMark,OPENPCD)也可公开从网上订购;再加上攻击算法效率的提高。实际上恶意用户破解M1密钥的成本(还包含时间成本)已经降到了很低的水平,已经达到大规模扩散所须要的条件。

公交卡系统将面临的攻击方式包含下面两种:

1)克隆:恶意用户通过破解现有合法卡的密钥并读取所有数据后,拷贝到多张空白IC卡上。

2)篡改:恶意用户通过破解现有合法卡的密钥后,直接篡改该卡的钱包剩余金额等重要数据。

从攻击效果来看,克隆可以在一张合法卡的基础上制作多张伪卡。而篡改仅仅能在合法卡本身的基础上制作伪卡。

因为现有M1卡採用了全球唯一的、不可篡改的uid物理卡号,而公交卡系统的密钥基本使用物理卡号进行分散计算获得,假设要实施克隆攻击。必须具备复制uid的能力,即具备M1卡的生产制造能力。而眼下可以生产兼容M1卡的是很有限的几个厂家,基本不可能自己做出非法克隆的事情,也不可能应恶意用户的要求进行订单生产。尽管通过硬件配合软件可以成功模拟M1卡而且可以与读卡器进行正常通讯,但离产品化还有较大距离。

有种观点觉得,仅仅要是採用了一卡一密、实时在线系统,或非接触逻辑加密卡的ID号。就能避免密钥被解密。事实上。非接触逻辑加密卡被解密就意味着M1卡能够被复制,使用在线系统虽然能够避免被非法充值。可是不能保证非法消费,即复制一张一样ID号的M1卡,就能够进行非法消费。如今的技术使用FPGA就能够全然复制。基于这个原理。Mifare的门禁卡也是不安全的。

事实上最重要的是。安全是一个系统级别的概念,安全的系统是有一系列的安全措施来保证的,比方密钥多级分散、比方用PSAM卡而不是终端自身软件计算密钥、比方卡片内保存密文而不是明文等等一系列的措施来添加终于破解的难度,并保证被破解后的损失减少到最低。安全不是仅仅靠单一的卡片来保证的。另外大家能够注意的是,终于破解卡片的事实上都不是软件暴力破解的,而是剖片等硬件手段起到了至关关键的数据。这事实上是对半导体厂商提出了更高的要求,怎样让逆向project的难度更大。所以不是说CPU卡就一定比M1卡安全,假设芯片自身的安全级别不够。通过剖片、甚至简单的黑客手段都能easy的获知卡片的password,那么是不是CPU卡事实上都毫无意义。并且CPU卡用的公开算法仅仅会让其安全性比M1还不如(算法破解都免了)。这就是为什么半导体厂商一直非常强调自己的芯片过了EAL5+认证。而国产芯片在这部分事实上还存在相当的差距。

文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38087245

MIFARE系列7《安全》的更多相关文章

  1. Mifare系列6-射频卡与读写器的通信(转)

    文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38085415 1. 复位应答(Answer to request) 读写器呼叫磁 ...

  2. Mifare系列1-简介(转)

    文章转自 文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38079827 感谢原创作者的辛勤,对您再次表达感谢! 随着社会的发展, ...

  3. MIFARE系列6《射频卡与读写器的通讯》

    1. 复位应答(Answer to request) 读写器呼叫磁场内的卡片,卡片对呼叫做出应答.对刚进入磁场得到电复位处于休闲状态的卡片,卡请求(REQA,0x26):对于已进行过读写操作并进入休眠 ...

  4. MIFARE系列1《MIFARE简介》

    随着社会的发展,智能卡在很多领域得到了广泛的应用.特别是非接触卡,由于使用方便以及功能强大的特点,在管理.公交.工作证.身份识别等领域得到了快速的普及和推广. 非接触卡已经逐步发展成为一个独立的跨学科 ...

  5. 射频识别技术漫谈(11)——Mifare系列卡的共性【worldsing笔记】

    Mifare是NXP公司生产的一系列遵守ISO14443A标准的射频卡,包Mifare S50.Mifare S70.Mifare UltraLight.Mifare Pro.Mifare Desfi ...

  6. 射频识别技术漫谈(11)——Mifare系列卡的共性

    Mifare是NXP公司生产的一系列遵守ISO14443A标准的射频卡,包Mifare S50.Mifare S70.Mifare UltraLight.Mifare Pro.Mifare Desfi ...

  7. MIFARE系列6《射频卡与读写器的通信》

    1. ATR(Answer to request) 读写器呼叫磁场内的卡片.卡片对呼叫做出应答. 对刚进入磁场得到电复位处于休闲状态的卡片,卡请求(REQA,0x26):对于已进行过读写操作并进入休眠 ...

  8. Mifare系列7-安全性(转)

    文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38087245 飞利浦的MIFARE卡 由于它的高安全性在市场上得到广泛应用,比如 ...

  9. Mifare系列5-存储结构(转)

    文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38081521 Mifare S50把1K字节的容量分为16个扇区(Sector0 ...

  10. Mifare系列4-组成(转)

    文/闫鑫原创转载请注明出处http://blog.csdn.net/yxstars/article/details/38081241 MIFARE集成电路芯片内含EEPROM.RF接口和数字控制单元. ...

随机推荐

  1. linux 经常使用配置

    教研室用的非常旧的fedora14,装一些软件和下载东西的时候比較蛋疼,恰巧ubuntu14.04 公布,于是安装试试,顺便记录下经常使用的配置,备忘. 1. 制作镜像,比較老的主板,写入方式选择US ...

  2. C#里System.Data.SQLite中对GUID的处理

    string sqlstring = "select * from endpoint_policy where HEX([UserGuid]) ='" + CommonHelper ...

  3. HDU 2815 Mod Tree 离散对数 扩张Baby Step Giant Step算法

    联系:http://acm.hdu.edu.cn/showproblem.php?pid=2815 意甲冠军: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQ ...

  4. PHP安装mcrypt.so报错 mcrypt.h not found 的解决的方法

    报错内容:configure: error: mcrypt.h not found. Please reinstall libmcrypt 网上搜索了非常多,包含自带的 yum install lib ...

  5. HttpLuaModule——翻译(Nginx API for Lua) (转)

    现在我已经将翻译的内容放到:http://wiki.nginx.org/HttpLuaModuleZh Nginx API for Lua Introduction 各种各样的*_by_lua和*_b ...

  6. MAC 10.10 apache 服务器配置

    mac中自带了apache服务器, 如果需要在mac上使用apache服务器, 只需要配置并启动服务器即可. mac 10.10 中自带的apache版本是 2.4 mac 10.9 中自带的apac ...

  7. 【C语言探索之旅】 第二课:工欲善其事,必先利其器

    内容简介 1.课程大纲 2.第一部分第二课:工欲善其事,必先利其器 3.第一部分第三课预告:你的第一个程序 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C ...

  8. 使用autoconf和automake生成Makefile文件(转)

    Makefile好难写 曾经也总结了一篇关于Makefile的文章<make和makefile的简单学习>.但是,总结完以后,发现写Makefile真的是一件非常痛苦的事情,的确非常痛苦. ...

  9. 具体的了解“&gt;/dev/null 2&gt;&amp;1”

    Linux系统中不管是crontab里面.还是平时使用的命令.常常会碰到">/dev/null 2>&1".比方说:在Crontab Job里面,假设不想发送邮 ...

  10. 学习vi和vim编辑(3):一个简单的文本编辑器(2)

    然后文章,继续评论vi编辑简单的文本编辑命令. 本文主要是删除的文字.复制,运动命令. 删除文本: 正如上一篇文章中讲过的,对于删除命令("d")也具有"(command ...