当前位置:文档之家› Mifare1射频卡操作原理(编程)

Mifare1射频卡操作原理(编程)

Mifare1卡及其读写器ASIC模块之“密码操作”研究与其应用程序开发关键字:非接触式智能卡 ASIC模块1、序言非接触式智能卡已经广泛地应用于各类门禁控制系统,公共交通支付系统,e-purse系统,高速公路不停车收费系统,IBMS(智能大楼管理系统),海关过境身份识别,以及医疗保险系统等等。

非接触式智能卡以其高度安全保密性,通信高速性,使用方便性,成本日渐低廉等而受到广泛使用,给我们的生活质量带来了很大的提高。

因此,如何认识、理解智能卡,特别是带有非常神秘色彩的非接触式智能卡,已引起很多智能卡的使用者,包括智能卡专业研发的IT科研人员的极大的兴趣和爱好。

笔者在此很愿意将自己多年来在智能卡(接触式智能卡及非接触式智能卡)方面的研究及其软硬件应用开发的经验与大家一同交流和分享,以取得我国金卡工程事业的更进一步的发展。

在此,笔者将以符合ISO/IEC14443TYPEA标准的Mifare1S50系列非接触式智能卡及其读写设备专用IC(ASIC)RC150/170模块为对象,与大家一起就“关于非接触式智能卡及其读写器ASIC模块之‘密码操作’”作一些研究与探讨,并将用标准的Intel-51系列微处理器汇编语言进行实际的应用程序的开发。

在笔者曾设计和开发的众多智能卡项目中,本文所给出的应用程序都有着良好的运行效果。

2、非接触式智能卡及其读写器ASIC模块RC150/170Mifare1S50非接触式智能卡片有着16个Sector(扇区);每个Sector包含4个Block(块);每个Block具有16个byte的存储容量。

Sector被定义为Sector0至Sector15;Block被分为Block0至Block3;整个Mifare1S50非接触式智能卡共有64个Block。

Sector0中的Block0记录了该张智能卡的序列号(SerialNumber)以及生产厂商的标志信息等,这些信息已在卡片出厂时固化,不能更改。

因此该Block不能再复用为应用数据块。

每个Sector中的Block3被特别用来存放对该Sector中应用块Block0,1,2及其本身Block3进行数据存取的密码及存取权限。

整个Mifare1S50非接触式智能卡共有16个Block3。

根据绝对地址编址,他们可被编为Block3(在Sector0中),Block7(在Sector1中),Block11(在Sector2中),以及Block63(在Sector15中)等等。

对于某一Sector中的Block3的绝对地址编址可以由下列公式计算得到:Block X=(N+1)*4-1其中:X:绝对地址编址的Block块号N:Sector扇号,0至15通常每个扇区的Block0,1,2都存放着非常保密的数据,例如坐公交车/出租车前在公交公司指定地点已购买的车资钱款,智能大厦/智能小区进出时所需的控制信息,股票交易时持有股票交易智能卡片者必须对已存放在智能卡中的交易密码数据(例如帐户、存款信息、已买进股票数量/品种等等)进行确认,才能得以股票交易,等等。

由于每一个Block3中包含了该扇区的密码字节以及对该扇区中其余Block0,1,2进行数据处理的存取控制权限字节,因此如何操作处理Block3将是很重要的内容。

以下将展开对每个扇区的Block3进行研究。

Block3有16个byte组成。

前6个字节是密码A(KEYA),KEYA的缺省值可能为“A0A1A2A3A4A5”;最后6个字节是密码B(KEYB),KEYB的缺省值可能为“B0B1B2B3B4B5”;中间4个字节是控制字节,缺省值可能为“FFH07H80H69H”;利用KEYA或KEYB并遵守早已定义在4个控制字节中的存取条件,我们便能对该密码(KEYA或KEYB)所对应的Sector内的应用块Block0,1,2进行数据读/写/更新等操作。

由于非接触式智能卡的操作,包括数据流的传递等都是以“非接触”方式来完成的,因此在MCU与非接触式智能卡之间必须有一个传递密码(或数据流)的中间媒体,即ASIC模块。

RC150/170就是这样一种ASIC模块。

它担负着非接触式智能卡与MCU(微处理机)之间所有的密码/数据相互传递的重要任务。

对非接触式智能卡进行密码操作,变成对RC150/170ASIC模块进行密码操作。

RC150/170ASIC模块与非接触式智能卡之间的信息传递(包括密码等)对用户来说是透明的,会自动传递并完成。

因此如何对非接触式智能卡进行“密码操作”(对Block3的操作)变成如何对RC150/170ASIC模块进行密码操作。

Philips公司的MCM200模块,MCM500模块或SB201,SB601(Uni-VisionEngineeringLtd.的产品)模块中都包含有RC150/170ASIC模块,因此本文所讨论的内容,包括下面设计的程序等,也适用于这些模块。

RC170是RC150的新一代ASIC模块,速度较快。

现在我们广泛使用的非接触式智能卡读写设备中大都包含有以上所列的ASIC模块之一。

图1显示了在用户(MCU)与非接触式智能卡之间基本的密码传输关系,并请特别注意ASIC 模块RC150/170的作用等等。

图1ASIC模块密码传输关系图在研究ASIC模块RC150/170的时候,我们必须关注所有与“密码操作”有关的寄存器/存储器的情况。

●密码数据寄存器KeyDataRegister(寄存器地址:0x0A);●密码地址寄存器KeyAddressRegister(寄存器地址:0x0C);●密码状态/控制寄存器KeyStatus&ControlRegister(KEYSTACON)(寄存器地址:0x0B);●其他相关寄存器。

所有这些与“密码操作”相关的寄存器都是“只可写不可读”的,即WOM(Write-Only-Memory)。

因此不要试图去读取这些寄存器的内容。

3、“密码操作”的研究及其应用程序开发通常,对非接触式智能卡的“密码操作”有两个主要步骤。

每一个主要步骤又有若干个小的步骤有序并且必须是连续地完成。

“密码操作”的两个主要步骤是:●“LOAD_KEY”密码存取●“AUTHENTICATION”密码认证3.1“LOAD_KEY”密码存取“LOAD_KEY”密码存取必须由以下步骤有序并连续地完成:●设置新的密码值●设置密码状态/控制寄存器KeyStatus&ControlRegister(KEYSTACON)●设置密码地址寄存器KeyAddressRegister(寄存器地址:0x0C)●设置密码数据寄存器KeyDataRegister(寄存器地址:0x0A)●校验STACON寄存器,以确定这次的“LOAD_KEY”密码存取是否有效以下将按照上述的次序进行具体的程序设计,所有的程序都使用标准的Intel-51MCU指令,以利于读者在LOW-LEVEL级上移植到其相应的应用项目中。

3.1.1设置新的密码值新的密码值为6个bytes,在如下的程序设计中被依次存放在MCU内部RAM的72H~77H的6个单元中;程序员亦可自定义其他的存储单元作为新的密码值存放的缓冲区;R1寄存器为新密码缓存首地址指针。

如下所设置新的密码值为:“AAAAAAAAAAAA”SETUP_NEW_KEY_VALUE:;MOV R7,#06H;密码长度为6bytesMOV R1,#72H;R1为新密码缓存首地址指针MOV @R1,#0AAH;设置新密码值MOV 73H,#0AAHMOV 74H,#0AAHMOV 75H,#0AAHMOV 76H,#0AAHMOV 77H,#0AAH良好的经验告诉我们,为了确保整个智能卡系统的高度安全保密,我们有必要在程序设计中,在完成了“密码操作”之后,立即清除存放新的密码值的缓冲区,简单的方法如下:CLEAR_NEW_KEY_BUFFER:MOV R7,#06H;密码长度为6bytesMOV R1,#72H;R1为新密码缓存首地址指针CLEAR_LOOP:MOV @R1,#00H;清除新密码值所在缓冲区INC R1DJNZ R7,CLEAR_LOOP3.1.2设置密码状态/控制寄存器KeyStatus&ControlRegister(KEYSTACON)KEYSTACON寄存器是一个只可读不可写的寄存器(存储器),它指示出“密码操作”时所处的状态和要控制的ASIC内部“密码存储器RAM”的选择。

这里所指的“状态”是指本次“密码操作”两个主要步骤中的一个。

KEYSTACON寄存器是一个8-bit的存储器,其中有用的位(bit)只有3位。

其具体内容为:其中,MSB(“A/L”位)若被设置为“0”,则意味着当前“密码操作”的“状态”是“LOAD_KEY(密码存取)”;若被设置为“1”,则当前“密码操作”的“状态”是“AUTHENTICATION(密码认证)”。

最后 2个bit:KS0KS1是密码集keyset的选择。

在ASIC中共有3套密码集(keyset)和一个传输密码(TransportKey)可被选择。

设置KS0、KS1的值实际上是在选择(寻址)ASIC模块内部存放密码的不同的存储器单元(密码箱)。

如果“LOAD_KEY”(密码存取)时使用了keyset0,则“AUTHENTICATION”(密码认证)时只能使用keyset0,而不能使用keyset1或keyset2或其他,因为在ASIC模块内,keyset0指定的密码存储器地址单元与keyset1或keyset2所指定的密码存储器地址单元是不同的单元。

这就好比去超级市场购物,入超市前您把您的包裹寄存在超市门前包裹箱A中,并得到打印有开起包裹箱A的(开箱)密码纸条;当您欲取回包裹时,拿着包裹箱A的(开箱)密码纸条而去开包裹箱B或C的箱门,当然不能打开,因为您的地址(箱号)不对,当然您的包裹也不能拿到。

这是密码的认证出错。

在ASIC中有相同之处。

如果“LOAD_KEY”(密码存取)时使用了keyset0,并存放上密码,而在“AUTHENTICATION”(密码认证)时却使用keyset1或keyset2或其他而来验证刚才存放的密码,当然会得到ASIC模块返回的认证出错(“AE=1”)。

当KS1KS0=“00”时,选择使用keyset0;当KS1KS0=“01”时,选择使用keyset1;当KS1KS0=“10”时,选择使用keyset2;当KS1KS0=“11”时,选择使用传输密码(TransportKey)。

以下是设置密码状态/控制寄存器KeyStatus&ControlRegister(KEYSTACON)的程序:SETUP_KEYSTACON:MOV 7EH,#00000000B;选择使用keyset0,并指明是“LOAD_KEY”MOV A,7EH ;7EH单元存放了设置KEYSTACON的值MOV R0,#0BH ;KEYSTACON寄存器地址为0BhOVX @R0,A ;设置KEYSTACON寄存器如果我们要选择使用keyset2,则相应可以设置7EH单元为#00000010b(0x02),即: MOV 7EH,#00000010B3.1.3设置密码地址寄存器KeyAddressRegister(寄存器地址:0x0C)在成功地完成了对密码状态/控制寄存器(KEYSTACON)的设置之后,必须立即对密码地址寄存器KeyAddressRegister进行设置,而不能对密码数据寄存器KeyDataRegister进行设置或做其他设置,否则将出错。

相关主题