MIFARE Classic S50技术详解
Mifare Classic 简介
MIFARE Classic是恩智浦半导体开发的可用于非接触式智能卡,符合ISO/IEC 14443 A类标准。用于公共交通票证等应用,还可用于各类其他应用有S20,S50(M1),S70几种规格,主要是根据存储器容量划分,存储器容量分别有320B,1K,4K。具有以下防干扰、轻松简便以及安全等特性:
- 防干扰
智能防干扰功能允许同时有多张卡在现场工作。防干扰算法分别选择每一张卡,并确保选定的卡正确执行交易,不会受到现场另一张卡的干扰。
- 轻松集成,使用简便
针对轻松集成和使用简便而设计,允许在不到100 ms的时间内完成整个票证交易。
- 安全
· 每器件具有制造商编程的7字节UID或4字节NUID标识符
· 支持随机ID
· 三道双向认证(ISO/IEC DIS 9798-2)
· 每扇区提供两组独立的密钥,支持多用途密钥体系
本文以S50进行着重讲解,对于S20及S70可访问官方网站详细了解。
逻辑框图
对于S50来说,芯片由1KB E2P,非接接口,数字控制单元组成。其中:
- 非接接口(RF Interface),包括:
· 调制解调器(Modulator/demodulator)
· 整流器(Rectifier)
· 时钟再生器(Clock regenerator)
· 上电复位(Power-On Reset )
· 电压调节器(Voltage regulator)
- 防冲突管理
- 认证管理
- 控制和算术逻辑单元
- 存储器及访问接口:对于S50来说,存储器(E2P)只需要1KB分为16个扇区,每个扇区为4块,每块16个字节,以块为存取单位。
- 加密单元
执行流程
执行流程包括三个部分,分别是初始化及选择过程,认证过程以及数据操作过程,如下图所示:
· 呼叫
读卡器发送 REQA/WUPA 命令,卡返回 ATQA 的过程。
· 防冲突循环
在防冲突循环过程中将读取卡片的ID,如果存在多张卡,则通过ID进行区别,并选择一张卡进一步处理,其它卡回到 IDLE 状态等待REQA/WUPA 命令。
· 选卡
读写器发送 SELECT,卡返回 SAK 的过程, SAK 指示当前卡是否支持 14443-4 协议和 UID 是否完整。
· 三轮认证
选卡后,读写器指定后续读写的存储器位置,并用相应密钥进行三轮认证。认证成功后,所有的存储器操作都是加密的。
· 存储器操作
认证后可执行下列操作:
- 读块
- 写块
- 减值:减少数值块内的值,并将结果保存在数据寄存器中。
- 加值:增加数值块内的值,并将结果保存在数据寄存器中。
- 恢复:将数据块内容移入数据寄存器。
- 转存:将数据寄存器的内容写入数值块。
数据存储结构
- 厂商代码块
这是第 0 区的第 0 块存储制造商代码,它含有 UID 和厂商数据,只读。如果是4字节UID,则0~3字节为序列号,第4字节为校验字节(异或值),第5字节国卡片容量,第6、7字节为卡片类型。
- 数据块
所有扇区都由3个块组成,每个块由16字节用于存储数据(扇区0只有两个数据块,一个只读的厂商数据块)。数据块可以设置为:
· 读写块,例如用于非接触门禁管理,有效命令: read, write
· 数值块,例如用于电子钱包。
- 数值块
数值块允许执行电子钱包功能(有效的命令是:读、写增量、减量、恢复、转移)。数值块有一个固定的数据格式允许错误检测和校正和备份管理。
· 数值:有符号 4 字节数值。数值的最低字节存储在最低地址字节。负值以标准的 2 的补码形式存储。数值存储三次,两次不取反,一次取反。
· 地址( Adr): 1 字节绝对地址,当进行备份管理时,可用于保存块的地址(即地址不一定与当前的块号相同)。地址保存四次,两次取反,两次不取反。在 increment、decrement、 restore 和 transfer 操作中,地址保持不变。它只能通过 write。
例:
对于十进制数1234567,地址17来说,首先十进制数转成十六进制为0x0012D687,低字节存储在第0字节,高字节为第3字节,补码为0xFFED2978,低字节存储在第4字节,高字节存储在第7字节。对于十六进制的地址0x11来说,补码为0xEE。存储结果如下表所示:
- 尾块
各区均有一个尾块,存有:
· 密钥 A 和 B(可选):卡片发行时,所有的密钥被设置为 FFFFFFFFFFFF。如果读密钥的权限不满足则读出的密钥值为全 0.
· 该区四个块(或16个块)的读写条件,存储在字节 6 至 9 。读写控制位也指定了数据块的类型(读写块或数值块)。
如果不需要密钥 B,尾块的最后 6 字节可以用作数据字节。尾块的字节 9 可用于用户数据。此字节享有与字节 6、 7、 8 相同的读写权限。对于访问条件,参考后面章节的详细说明。
访问控制
任何内存操作之前,卡必须选择和验证,对一个特定的块的访问,依赖于验证过程中的密钥以及存储在当前的扇区尾部的访问条件。内存操作如下表所示:
- 访问条件
每个数据块和尾块的访问条件是由3位数据组成,在访问条件及其补码形式存储在指定块的尾块中。
访问控制位使用密钥A和密钥B控制内存的访问,访问条件可能会改变,只要知道相关的密钥和当前访问条件即允许此操作。如下图所示:
- 控制位的组成
- 尾块访问条件
根据尾块的访问控制位,对于key的读/写访问的权限包括:never,keyA,keyB或者keyA|B。
卡片发行时的控制字节为: FF078069,即:
C10 C20 C30=000,块 0 的读、写、增、减、恢复、传送的权限都是 key A 或 keyB
C11 C21 C31=000,块 1 的读、写、增、减、恢复、传送的权限都是 key A 或 keyB
C12 C22 C32=000,块 2 的读、写、增、减、恢复、传送的权限都是 key A 或 keyB
C13 C23 C33=001,块 3 的 keyA 读权限 never, keyA 的写权限、 Access bits 和 keyB 的读写权限都是 keyA。
例一: C11 C21 C31=010,即块 1 的读权限为 keyA/keyB,写、增、减、恢复、传送的权限为never。修改尾块的值为: FFFFFFFFFFFFDF078200FFFFFFFFFFFF
例二: C1x C2x C3x=111,即数据块的所有权限都为 never,尾块的读控制字节权限为 keyA|B,
其它权限为 never。
修改尾块的值为: FFFFFFFFFFFF00F0FF00FFFFFFFFFFFF
- 数据块访问条件
根据访问控制位的数据块(块0~2),读/写访问被指定为“从不”,“KeyA”,“KeyB”或“KeyA| B”。访问控制位定义了应用程序和相应的适用的命令。
•读/写块:允许读和写操作。
•数值块:允许额外的值操作,增量、减量、转移和恢复。
•制造商块:只读,不受访问控制位设置影响!
•密钥管理:在运输时配置必须用于身份验证的KeyA
执行命令
MIFARE Classic卡激活遵循ISO / IEC 14443 TypeA,MIFARE Classic卡被选中后,它可以使用ISO / IEC 14443命令停用,或可以执行MIFARE Classic命令。
- ACK与NAK
Mifare classic 使用4位ACK/NAK,如下表所示:
- 个人化
- SET_MOD_TYPE命令
- 认证命令
- 读命令
- 写命令
- 增、减、恢复命令
- 转存命令
安全与保护
- 数据完整性
以下机制在非接通讯过程中于读卡器与卡片之间实现,卡片确保数据正确性:
•每个数据块有16位CRC
•为每个字节奇偶校验位
•位数检查
•位编码区分“1”,“0”和“无信息”
•监测信道(协议序列和位流分析)
- 三轮认证
1. 卡从指定扇区的尾块读出密钥和访问权限,并产生 4 字节随机数发送给读卡器。
2. 读卡器使用密钥加密收到的随机数,把加密结果连同自己产生的随机数一起发送给卡(共 8 字节)。
3. 卡使用第 1 轮中读出的密钥验证读卡器返回的加密数据,如正确则把收到的随机数加密后发送给读卡器,否则不发送数据。
- RF接口
RF-interface根据非接触式智能卡ISO / IEC 14443标准实现。两个方向的数据通信在每一帧的开始只有一个起始位。每个字节一位校验位(奇校验)。选择块的最低(LSB)的字节最选传输,最大帧长度为163位(16字节数据+ 2 CRC字节= 16´2´9 + 9 + 1起始位)。
资料参考
1.官方网站:http://www.nxp.com
2.MIFARE Classic EV1 1K - Mainstream contactless smart card IC for fast and easy solution development.pdf Rev. 3.0
3.MIFARE Platform Update &Infrastructure Introduction. Steven CJ Chang 2012.Feb.27
4.《智能卡技术》
MIFARE Classic S50技术详解相关推荐
- 《视频直播技术详解》系列:(6)编码和封装
原文来自七牛云,感谢原作者. <视频直播技术详解>系列:(0)汇总 视频编码是本系列一个重要的部分,如果把整个流媒体比喻成一个物流系统,那么编解码就是其中配货和装货的过程,这个过程非常重要 ...
- 《视频直播技术详解》之二:编码和封装、推流和传输
视频编码是本系列一个重要的部分,如果把整个流媒体比喻成一个物流系统,那么编解码就是其中配货和装货的过程,这个过程非常重要,它的速度和压缩比对物流系统的意义非常大,影响物流系统的整体速度和成本.同样,对 ...
- 【H.264/AVC视频编解码技术详解】十九:熵编码算法(5)——H.264的CABAC(上):语法元素的二值化方法...
<H.264/AVC视频编解码技术详解>视频教程已经在"CSDN学院"上线,视频中详述了H.264的背景.标准协议和实现,并通过一个实战工程的形式对H.264的标准进行 ...
- Linux磁盘阵列技术详解(二)--raid 1创建
我在Linux磁盘阵列技术详解(一)里已经详细介绍了几种RAID磁盘阵列方式,原理以及创建raid 0 的详细步骤.那么这篇文档就着重讲解如何创建raid 1的技术: 步骤如下: ① 分区 同样我们还 ...
- 《Hadoop技术详解》一导读
前 言 Hadoop技术详解 本书采用的约定 本书采用以下排版约定. 斜体 用于表明新的术语.URL.电子邮件地址.文件名和文件扩展名. 等宽字体 用于程序清单,正文段落中有关的程序元素,如变量及函数 ...
- 科普:5G网络关键技术详解
不久前,中国华为公司主推的Polar Code(极化码)方案,成为5G控制信道eMBB场景编码方案.消息一出,在网络上就炸开了锅,甚至有媒体用"华为碾压高通,拿下5G时代"来形容这 ...
- zookeeper 分布式过程协同技术详解.pdf_阿里大牛耗时18个月整理这份ZooKeeper分布式详解文档...
前言 摩尔定律揭示了集成电路每18个月计算性能就会增加一倍.随着信息的飞速膨胀,很多应用都无法依赖单个服务器的性能升级来处理如此庞大的数据量,分布式系统和应用越来越受到人们的青睐.分布式系统和应用不仅 ...
- Qtum量子链研究院:Plasma技术详解(下篇)
Plasma的设计模型有两个主要的分支:Plasma MVP(Minimal Viable Plasma,最小可行的Plasma)和Plasma Cash.Plasma MVP的目标是为最基本的可用的 ...
- Python数据科学-技术详解与商业实践视频教程
Python数据科学-技术详解与商业实践(八大案例) 网盘地址:https://pan.baidu.com/s/13QrR_5Er6LgWCWzSb7qOrQ 提取码:s7vw 备用地址(腾讯微云): ...
最新文章
- 编写fun函数判断字符串尾部的*号,若多于指定数量,则删除多余的;否则,不做操作
- UVA 1415 - Gauss Prime(数论,高斯素数拓展)
- webapi添加html页面,如何从WebApi动作返回html页面?
- Microsoft Exchange 2010 安装配置
- new Fiori 2.0 theme sap_belize
- 不愿意和别人打交道_最不愿与陌生人打交道的星座
- Spring Web应用程序的最大缺陷
- 深度解析Cocoa异步请求和libxml2.dylib教程(1)
- 纯css3特效实现的文字亮光
- [转载] 交互式数据可视化在Python中用Bokeh实现
- Hello designer|PPT笔记
- 【科普】AHCI模式是什么,与IDE模式有什么区别?
- maxscale跨库分片的限制
- 中秋节主题征文 | 那些不朽的描写月亮的诗词
- usaco Raucous Rockers
- 转-注册表对应项详解
- 闪电分镜 一款影视前期策划的完美解决方案
- 前端 - a标签target=”_blank”
- WiFi(Wireless Fidelity)基础(四)
- 建筑力学与结构【11】