CPU卡的接口特性、传输协议与读写程序设计培训讲学_第1页
CPU卡的接口特性、传输协议与读写程序设计培训讲学_第2页
CPU卡的接口特性、传输协议与读写程序设计培训讲学_第3页
CPU卡的接口特性、传输协议与读写程序设计培训讲学_第4页
CPU卡的接口特性、传输协议与读写程序设计培训讲学_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Good is good, but better carries it.精益求精,善益求善。CPU卡的接口特性、传输协议与读写程序设计-CPU卡的接口特性、传输协议与读写程序设计摘要介绍ISO78164及中国金融集成电路(IC)卡规范所规定的T=0协议的CPU卡与终端之间的接口特性和传输协议,及以C51语言设计的CPU卡复位、下电及读写程序。关键词IC卡CPU卡终端复位字符传输协议(T=0协议)IC卡的概念是20世纪70年代提出的。法国BULL公司首创IC卡产品,并将这项技术应用到金融、交通、医疗、身份证明等多个方面。IC卡的核心是集成电路芯片,一般为3m以下的半导体技术制造。IC卡具有写入数

2、据和存储数据的能力。IC可存储其中的内容,根据需要可以有条件地供外部读取,或供内部信息处理或校验用。根据各种集成电路的不同,IC卡可以分为以下三类:存储器卡、逻辑加密卡与CPU卡。其中,存储器卡仅有数据存储能力,没有安全措施;逻辑加密卡仅有几个字节的密码,卡中有一个错误计数器,如果指定次数验证密码失败,则卡中数据被自动锁死,该卡数据不能再更改;CPU卡是这三类IC卡中最高级的卡,一般有ROM、RAM和EEPROM三种存储器。ROM中存放的是程序,程序是为IC卡的CPU专门设计的,用来解释读写器终端送来的命令。IC卡应用系统根据应用需要由终端送一系列命令到CPU卡,通过改变命令的内容和命令的顺序

3、就可以满足不同的需要,因此有较高的灵活性;同时,因为CPU有计算功能,存储容量又大,可以进行比较复杂的加密/解密运算,极大提高了安全性。EEPROM主要用来存放一些应用数据,其容量比逻辑加密卡大,可实现一卡多用,是目前最安全的卡类型。因此,CPU卡是目前IC卡的重要发展方向之一。1CPU卡的接口特性1.1触点定义触点的定义遵循ISO78162的规定,如图1所示。符号说明如表1所列。图1CPU卡的触点表1符号说明1.2字符帧数据在I/O上以图2所示的字符帧方式传输。图2字符帧传输方式每个位宽是1个etu,etu=372/f。在此处,f=3.57MHz。起始位由接收端通过对I/O周期采样获得,采样

4、周期应小于0.2etu。2个连续字符起始位上升沿之间的间隔时间等于(100.2)etu加上1个保护时间(最少2个etu)。在保护时间内,卡与终端都应处于接收模式(I/O为高电平状态)。如果卡或终端作为接收方检测出奇偶错误,则I/O被置为低电平,以向发送方表明出现错误。1.3卡操作卡操作的步骤如下:将卡插入终端接口设备,使两者的触点相接并激活触点;将卡复位,建立卡与终端间的通信;执行操作;释放触点,并从接口设备取出卡片。以下是除第步(执行操作)以外,各步的时序要求。(1)触点激活时序如图3所示。图3触点激活时序(2)卡复位卡利用低电平复位来完成异步复位应答,随着触点的激活,终端将进行一个冷复位并

5、从卡获得复位应答。冷复位时序如图4所示。图4冷复位时序冷复位过程之后,如果收到的复位应答信号不满足标准的规定,终端将启动一个热复位并从卡获得复位响应。热复位时序如图5所示。图5热复位时序在实际程序设计时,由Reset子程序实现触点激活和卡复位。(3)触点释放时序触点释放时序过程如图6所示。图6触点释放时序2传输协议与卡命令处理程序ISO78164及中国金融集成电路(IC)卡规范所规定的异步半双工传输协议,是关于终端为实现传输控制和特殊控制而发出的命令的结构及其处理过程,包括了两种协议:字符传输协议(T=0)和块传输协议(T=1)。本文着重讨论字符传输协议(T=0)协议,它是IC卡推荐使用的通信

6、协议。2.1命令命令包含1个连续4字节的命令头,用CLA、INS、P1和P2以及1个可变长度的条件体来表示。命令头定义如下:CLA:指令类别,除FF外的任何值;INS:在指令类别中的指令码,当最低位是0,并且高位半字节既不是6也不是9时,INS才有效;P1、P2完成INS的参数字节。条件体定义如下:Lc(发送数据长度)占1个字节,在命令中定义为发送数据的字节数,取值范围是1255。Data为将要发送的命令数据域,字节数由Lc定义。Le(接收数据长度)占1个字节,指出命令响应中预期的数据最大字节数。Le的取值范围是0255。如果Le=0,预期数据字节的最大长度是256。可能的命令结构的4种情况定

7、义如表2所列。表2命令全部由终端应用层(TAL)初始化。它通过终端传输层(TTL)向卡发送1个由5个字节组成的命令头,并等待一个过程字节。2.2过程字节卡收到命令后,紧接着返回一个过程字节给TTL,指明下一步该作什么,如表3所列。表3在(1)、(2)情况中,TTL完成动作后将等待另一个过程字节。在(3)情况中,第二个过程字节或状态码(SW2)被收到后,TTL将做以下事情:如果过程字节为61,TTL将发送一个最大长度(P3)为XX的得到响应命令(GETRESPONSE)给卡,XX为SW2的值。GETRESPONSE命令仅适用于T=0协议。命令报文的结构如表4所列。表4如果过程字节为6C,TTL将

8、立即重发前一个命令的命令头给卡,它的P3值用XX代替。XX是SW2的值。如果过程字节是6X(除60、61及6C之外)或9X,与前两者TTL自己处理不同,TTL将通过命令响应返回状态码给上一层-终端应用层(TAL),由TAL处理,并等待下一个命令。2.3卡命令处理程序流程图图7是卡命令处理程序,即终端与卡的信息交互过程的流程图,具体程序见本刊网站。图7卡命令处理程序流程图以下是引脚说明。ECPU:决定卡的CLK触点上是否有CLK信号的引脚;ICVCC:终端与卡的Vcc触点相接触的引脚;ICIO:终端与卡的I/O触点相接触的引脚;ICCLK:终端与卡的CLK触点相接触的引脚;ICRST:终端与卡的RST触点相接触的引脚。以下是程序中函数介绍。voidisr_timer1(void)interrupt3:定时器1中断子程序,用于按位发送和接收数据字节;voidSnd(void):发送数据子程序,由定时器1实现;voidRcv(BYTEbytenr,BYTE*Buffer):接收数据子程序(参数含义分别是:接收数据字节数、接收数据的存放处),由定时器1实现;函数1voidReset(BYTE*len,BYTE*resp):复位子程序(参数含义分别是:返回复位响应数据的长度、复位响应数据);函数2v

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论