射频智能卡密码认证功能实现_第1页
射频智能卡密码认证功能实现_第2页
射频智能卡密码认证功能实现_第3页
射频智能卡密码认证功能实现_第4页
射频智能卡密码认证功能实现_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

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

文档简介

1、 射频智能卡密码认证功能实现深圳职业技术学院 柴继红MIFARE 1卡的读写操作步骤 激活MCM MCM软复位 向MCM下载密码(LOAD KEY),校验传输密码正确后可向MCM的KEY-RAM写入用户自己设定的密码以上操作与卡无关 请求应答(ANSWER TO REQUEST):寻卡 防冲突(ANTICOLLISION):选择唯一一张卡 选择标记(SELECT):激活所选择的卡 认证认证 (AUTHENTICATIONAUTHENTICATION):安全性):安全性 读写操作(读、写、加值、减值):交换数据 (READ/WRITE/INCREAMENT/DECREMENT) 停止(HALT)

2、:置卡为停止模式,防止重复操作。 while(1) tmpMODE=RF_CMD_REQUEST_STD; /设置防冲突命令码 Status = Request(tmpMODE);/ Request standard请求应答,寻卡/14443 A卡返回 tagtype2=0 x04,0 x00 if(Status=MI_OK) Status = AntiColl(); / Anticollision防冲突,在多张卡中选择一张/卡返回UID5 if(Status=FM1702_OK) Status=Select_Card(); /Select application选择应用,激活选中的卡/卡返回

3、SIZE字节cardtype=0 x08/0 x88/0 x18/0 x04/0 x28/0 x53 MIFARE卡读写范例程序 if(Status=FM1702_OK) secnum=1; /secnumsecnum=1; /secnum为要认证的扇区号为要认证的扇区号015015,扇区,扇区1 1keytype=0; /keytypekeytype=0; /keytype为要认证的密码类型,为要认证的密码类型,0-0-密码密码A A,非,非0-0-密码密码B B Status = loadkey_e2(secnum,keytype); /Status = loadkey_e2(secnum

4、,keytype); /密码装载密码装载Status = Authentication1(UID, secnum,keytype); /Status = Authentication1(UID, secnum,keytype); /密码认证密码认证 blkaddr=4; /块地址063,扇区1块0if(Status=FM1702_OK) Status=MIF_Read(blockdata,blkaddr); /读块数据blockdata0=blockdata0-3;/在块的第0个字节修改数据if(Status = FM1702_OK) Status=MIF_Write(blockdata,bl

5、kaddr); /写入修改后的块数据 if(Status=FM1702_OK)Status = MIF_Halt(); /暂停 装载工程在Keil中打开RF test工程项目文件,编译后下载到开发调试平台将Mifare 1卡置于读写器天线范围内 断点调试在Mifare 1卡读写范例程序中调用Authentication函数后设置断点添加函数返回状态变量Status到观察窗口运行程序,观察并记录卡的响应即状态变量Status 做一做:Authentication功能调试loadkeye2 装载密码指令q 函数的密码装载功能 Mifare卡读写芯片只能从内部的密钥缓冲区中读出密钥,因此在启动认证前

6、必须将先调用此函数将密钥从EEPROM装载到密钥缓冲区中 q 函数原型ucharloadkey_e2(uchar Secnr,ucharmode)参数参数 Secnr为要认证的扇区号015, mode为要认证的密码类型,0-密码A,非0-密码B 返回值返回值 正常则返回0(FM1702_OK),否则返回错误代码q 函数的编程调用 if(Status=FM1702_OK) secnum=1;/扇区1 keytype=0;/密码A Status = loadkey_e2(secnum,keytype); Authentication 密码认证指令q 函数的密码认证功能 将读写模块密码存储器中的密码与卡中对应的密码进行三次相互认证q 函数原型uchar Authentication1(uchar *UID,uchar SecNR,uchar) 参数参数 UID为要认证的卡号, Secnr为要认证的扇区号015,mode为要认证的密码类型卡应答卡应答 卡应答以AE位给出;AE=1/0,密码出错/正确,未能通过/通过认证返回值返回值 正常则返回0(FM1702_OK),否则返回错误代码q 函数的编程调用 if(Status=FM170

温馨提示

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

评论

0/150

提交评论