智能卡门禁系统设计Word文件下载.docx
《智能卡门禁系统设计Word文件下载.docx》由会员分享,可在线阅读,更多相关《智能卡门禁系统设计Word文件下载.docx(35页珍藏版)》请在冰点文库上搜索。
![智能卡门禁系统设计Word文件下载.docx](https://file1.bingdoc.com/fileroot1/2023-5/5/7425c3ea-ec99-44bb-a841-e8fac88a3291/7425c3ea-ec99-44bb-a841-e8fac88a32911.gif)
外围配有RS232转RS485接口能与PC机互连成网络,可以完成读卡、显示卡号和出入时间、身份识别、开锁以及保存和上传出入记录、下载黑名单、设置开门权限等功能。
门禁机模块的主控软件主要完成门禁机模块的初始化、卡的识别、开启门锁及保存有关数据和数据的传输等五大功能。
其总体工作流程如图5。
2所示:
图3非接触式IC卡门禁机总体工作流程
在完成整个门禁机模块的设计和制作前,首先必须明确非接触式IC卡读写模块的功能特性、接口规范和控制方式.本系统选用MIFARE1卡作为门禁钥匙,相应地,选用广州周立功公司的ZLG500A读写模块作为卡与门禁机交换数据的接口模块。
1.ZLG500A读写模块特性
1)功能特性
图5。
3为ZLG500A非接触式IC卡读写模块,该模块采用最新PHILIPS高集成ISO14443读卡芯片-MFRC500,能读写RC500内EEPROM,提供三线SPI接口,并具有控制线输出口,能与任何MCU接口。
此外,该模块四层电路板设计,双面表贴,EMC性能优良;
并自带无源蜂鸣器信号输出,能用软件控制输出频率及持续时间。
J1J2
图4ZLG500A模块实物图
如图5.3所示J1为与天线的接口J2为与MCU的接口,J1、J2的管脚排列和功能说明见表5.1:
表5。
1ZLG500A非接触式IC卡读写模块管脚说明
(一)
管脚
符号
描述
J1-1
GND
地
J1-2
TX1
天线发送1
J1—3
J1—4
TX2
天线发送2
J1-5
J1-6
RX
天线接收
1ZLG500A非接触式IC卡读写模块管脚说明
(二)
类型
J2—1
SCLK
输入
三线SPI接口时钟线总是由外部MCU产生
J2—2
SDATA
双向
数据线可双向传输
J2-3
SS
传输启动线接MCU外部中断
J2—4
VCC
PWR
电源正端
J2-5
RST
复位
内部MCU复位端高电平有效
J2—6
电源负端
J2-7
CTRL
输出
控制线输出
J2-8
BZ
蜂鸣器信号输出
ZLG500模块可方便地与任何MCU进行接口,如图5。
4所示为ZLG500与MCS-51单片机
4ZLG500与MCS—51单片机接口图
的典型接口。
SCLK、SDATA、SS为ZLG500A与MCU相联接的控制线,分别为片选SS、时钟线SCLK和数据线SDATA。
主控制器的MCU和读卡模块内的MCU通过此三线相连,三根线上的实际电平是双方口线状态逻辑线与的结果.
2)ZLG500三线串行读卡模块接口规范
(1)接口原理
接口空闲时主机SS=1SCLK=0SDATA=0从机SS=1SCLK=1SDATA=0。
其中SS和DATA是双向的而时钟线SCLK是单向的,即时钟只能由主控制器产生,该信号必须严格遵守时序规范,否则将出现通信错误读卡模块必须释放该线。
SS为数据发送使能,若一方有数据要发送给另一方,则该方控制SS线为低并在发送结束后将该线置高,接收数据方不得控制该线,双方必须遵守通信协议不得同时控制该线。
SDATA为数据线,由数据发送端控制数据,接收端必须释放该线.该线在一次传输开始时还同时作为数据接收端的响应信号。
(2)时序图
如图5。
5所示,无论数据传输的方向如何,SPI线上信号的波形总是如下;
图5ZLG500时序图
由图中可以看出,在SS为低的情况时,时钟和数据线上的信号才有效。
且在SCLK为低时SDATA变化,在SCLK为高时SDATA应保持稳定.
以上传输中从数据发送器请求开始至数据接收器响应的时间是不确定的,取决接收器内的MCU是否忙,有必要设置一个看门狗定时器对数据接收器的响应进行监视,一旦接收器响应,则MCU必须根据数据传输的方向,严格控制以下几个时间,以确保数据传输无误。
t1-数据接收器响应至MCU产生第一个SCLK上升沿的时间。
t2—两个字节传输之间SCLK低电平的持续时间。
t3-传输最后一个字节的最后一位的SCLK信号的上升沿至SS上升沿的时间。
tH—SCLK信号的高电平持续时间。
tL—SCLK信号的低电平持续时间。
在数据传输的方向不同时,对时间t1-t3tH和tL都有各自不同的要求。
(3)通信协议
MCU与ZLG500的通信必须先由MCU发送命令和数据给ZLG500,ZLG500执行命令完毕后,将命令执行的状态和响应数据发回MCU。
开始通信前,收发双方必须处于空闲状态。
首先由MCU发出SS下降沿信号,然后等待ZLG500载SDATA线上的响应,若在50ms内为检测到此信号,则退出本次传输。
若正确响应,则MCU可将命令和数据发送出去。
然后MCU等待ZLG500发回的状态和响应数据。
也即等待SS线上的下降沿信号,若在50ms内为检测到此信号,则退出本次传输,若正确检测到SS信号,则可以接收状态和数据.
ZLG500初始化的子程序如下:
SCLKBITP1.0
SDATABITP1。
1
SSBITP1.2
RSTBITP3.3
Zlg500:
SETBRST;
ZLG500内部复位
LCALLDELAY_50MS
CLRRST
SETBSS;
处于空闲状态
CLRSDATA
CLRSCLK
MOV58H,#11H
MOV59H,#11H
MOV5AH,#11H
MOV5BH,#11H
LCALLCONFIG;
配置
LCALLREQUEST;
发送请求
LCALLANTICOLL;
防碰撞
;
***********IFHAVECARD***********
MOVA,52H
CJNEA,#04H,SA123;
A=04ISNOCARD
LJMPSA234
SA123:
RET
SA234:
LCALLREAD_BLOCK;
从存储器中读取数据
LCALLDELAY_100MS
MOVR2,#20
MOVR0,#58H
MOVR1,#80H
LCALLCOMPARE;
进行卡号的比较和验证
REL13:
SETBFLAG
LCALLREL123
JBFLAG,REL13
RET
上述程序中CONFIG子程序为RC500的复位和配置子程序,是由MCU向ZLG500发出的不带数据的命令程序;
REQUEST子程序是MCU向ZLG500发出的带一个字节数据的命令程序,主要是检查在有效范围内是否有卡存在;
ANTICOLL子程序是防冲突操作,必须在执行了REQUEST命令后立即执行。
MCU与ZLG500之间的通信一般遵循如下的数据格式
MCU向ZLG500发出的命令模式的格式如下:
SeqNr
Command
Len
Data[0…N]
BCC
INFO[0]INFO[n]
其中:
SeqNr:
1Byte是数据交换包的序号
Command:
1Byte是命令字符
Len:
1Byte是数据的长度
Data[…]LenByte是数据字节
BCC:
1Byte是一个字节的BCC效验
Status
Data[0…N]
INFO[0]INFO[n]
status:
1Byte是状态字符
Len:
BCC:
按照上述数据格式传输编制的CONFIG、REQUEST和ANTICOLL子程序清单如下:
;
**************CONFIG***********************
CONFIG:
MOV60H,#00H;
数据交换包的序号
MOV61H,#52H;
配置命令字符代码
MOV62H,#00H;
数据的长度为0
LCALLBCC_SUM0;
BCC效验子程序
MOV63H,A;
BCC_SUM
MOVA,#00H
MOVR2,#04H
MOVR0,#60H;
发送首地址
LCALLSPI_SEND
MOVR0,#30H;
接收起始地址
LCALL_SPI_RCV
***************REQUEST***********************
REQUEST:
MOV60H,#00H;
MOV61H,#41H;
请求命令字符代码
MOV62H,#01H;
数据的长度为1
MOV63H,#01H;
请求模式的数据mode=01H
LCALLBCC_SUM
MOV64H,A
MOVA,#00H
MOVR2,#05H;
发送5个字节数
MOVR0,#60H;
60H_64H的数据发送
;
MOVR0,#40H;
LCALLSPI_RCV
**************ANTICOLL***********************
ANTICOLL:
MOV60H,#00;
MOV61H,#42H;
防碰撞命令字符代码
MOV62H,#01;
MOV63H,#00H;
数据值为0
LCALLBCC_SUM
MOV64H,A
MOVA,#00H
MOVR2,#05H;
发送5个字节数MOVR0,#60H;
MOVR0,#50H;
存放数据
MOVA,52H
CJNEA,#04H,L0
MOV58H,53H
MOV59H,54H
MOV5AH,55H
MOV5BH,56H
MOVA,58H
XRLA,59H
XRLA,5AH
XRLA,5BH
MOV5CH,A
CLRP3.4
LCALLDELAY_50MS
SETBP3。
4
L0:
RET
3)写数据MCU—-ZLG500
除响应信号外,三根线上的信号全由MCU产生。
MCU在SS线上产生一个下降沿,发出请求数据传输的信号,等待ZLG500响应后本次数据传输开始,ZLG500将在SCLK为高时读取SDATA线上的数据,传输完毕后MCU应在SS线上产生一个上升沿结束本次传输。
写数据的具体步骤可见表5。
2.
2ZLG500A读写模块写数据步骤
序号
动作发出者
动作
动作接收者
动作说明
MCU
SDATA=1SCLK=0SS=下降沿
ZLG500
本次数据传输开始请求
2
SDATA=上升沿
本次数据传输响应
3
SDATA=串行数据
数据传输
SCLK=上升沿、延时、下降沿
产生时钟ZLG500读数据
5
重复动作3、4传送N8位
数据传输N字节
6
SS=上升沿SDATA=0SCLK=0
本次数据传输结束
传输过程中必须严格遵守以下时间要求:
t1>
7s,t2>
14s,tH〉7s,tL〉9s,t3=任意
下面是MCU向ZLG500写入数据的子程序,为满足上述时间要求,可通过加入空操作来实现。
SPI_SEND:
ANLP3,#0F7H;
恢复SS的输出功能,传输开始请求
DECR0;
发送数据的首地址
SETBSDATA
JBSDATA,$;
SADATA仍为高则等待
CLRSS
MOVR5,#100
DL33:
MOVR6,#7DH
DL44:
JBSDATA,ASDF;
MCU等待SDATAD的上升沿
DJNZR6,DL44
DJNZR5,DL33
AJMPSPI_SEND
ASDF:
ANLP1,#0FDH;
STADA恢复输出
SENDBYTE:
NOP
INCR0
NOP
MOVA,@R0
MOVR3,#8;
设置一个字节的位数
SENDBIT:
NOP
RLCA
MOVSDATA,C;
发送数据位
SETBSCLK:
DJNZR3,SENDBIT
DJNZR2,SENDBYTE
SETBSS;
本次数据传输结束
JBSS,$
4)读数据ZLG500——MCU
响应信号SCLK信号由MCU产生,SS信号和SDATA信号由ZLG500产生。
ZLG500会在SS线上产生一个下降沿发出请求数据传输的信号,等待MCU响应后本次数据传输开始,MCU将在SCLK为高时读取SDATA线上的数据,传输完毕后ZLG500将会在SS线上产生一个上升沿结束本次传输.读数据的具体步骤可见表5。
表5.3ZLG500A读写模块读数据步骤
动作
发出者
接收者
SDATA=1SS=下降沿
MCU产生时钟,且读取数据
双方
数据传输N字节
SS=上升沿,SDATA=0
传输过程中必须严格遵守以下时间要求
14s,t2>
16s,tH〉6s,tL>
6s,t3〉9s
下面是MCU从ZLG500读取数据的子程序,同理,为满足上述时间要求,可通过加入空操作来实现。
SPI_RCV:
ORLP3,#08H;
SS设置为输入
ANLP1,#0FDH;
SDATA设置为输出
DECR0
ORLP1,#02;
SDATA设置为输入
RCVBYTE:
MOVR3,#8
RCVBIT:
SETBSCLK
MOVC,SDATA;
读取一位
DJNZR3,RCVBIT
MOV@R0,A;
读取的一个字节存入指定地址
JNBSS,RCVBYTE
SDATA设置为输出
RET
2.门禁机主控模块
上面我们对ZLG500A读写模块的功能特性、接口规范和控制方式作了比较详细地讲解,在此基础上,可以进一步完成MCU对ZLG500A的读写和控制,如果附加上周边的辅助功能和驱动控制,就可以形成一个完整的智能卡读写器.
首先,我们看一下MCU部分的设计和控制的实现。
图5.6是MCU控制框图,从图中可以看出MCU除了完成对ZLG500A读写模块的控制外,还要承担其它功能的控制,主要包括四大部
图6门禁机控制框图
分:
键盘和显示部分、实时时钟和掉电保护部分、数据存储和数据传输部分、驱动控制部分。
1)键盘和显示部分
键盘和显示是一般智能化仪器仪表均须具有的功能,是人机交互最主要的方式。
不同的智能仪器,随着其功能、MCU资源的占用、使用环境等各种条件的不同,可采用多种键盘和显示方案.本应用系统中,由于外围部件较多,MCU资源占用较大,为了尽可能的减少MCU输入输出I/O的占用,键盘的设计采用串入并出的方式,利用一片74LS164,占用MCU的四根I/O口,就可以实现16个键的全部功能。
具体电路见图5.7:
图7串行口扩展的行列式键盘
从系统监控软件的角度来看,仅仅完成键盘扫描,读取当前时刻的键盘状态是不够的,还有不少问题需要解决,否则,在操作键盘时就容易引起误操作、失控等现象。
首先是去抖动处理。
按键的触点在闭合和断开时均会产生抖动,这时触点的逻辑电平是不稳定的,如不妥善处理,将会引起按键命令的错误执行或重复执行。
最常用的一种方法是软件延时的方法来避开抖动阶段,延时过程一般取10ms~50ms.
其次是连击的处理。
当按下某个键时,键盘处理程序便查找相应的功能号,并转到相应的功能模块程序去执行,如果这时操作者还没有释放按键,MCU就会反复执行该按键对应的功能,好像操作者在连续操作该键一样。
本系统中需要按键去改变系统的实时日历,如果出现连击现象,操作者就很难设定时间.要解决连击的问题最关键是一次按键只让它响应一次,该键不释放就不执行第二次。
为此要分别检测到按键按下的时刻和释放的时刻。
有两种程序结构都可以解决连击的问题,一是按下键盘就执行,执行完成后等待操作者释放按键,在末放前不再执行指定的功能,从而避免了一次按键重复执行的现象。
二是在按键释放后再执行指定的功能,同时可以避免连击,但与前一种相比,给人一种反应迟钝的感觉。
具体采用哪种结构,可根据实际情况而定.
关于键盘控制的具体编程,可参考有关的书籍和应用说明,在此就不再说明。
显示是人与计算机系统打交道所必不可少的部分,本系统要求门禁在不打卡时具备显示当前时间,打卡时显示该卡卡号及打卡时间。
为此,选用了具有有良好的显示界面的图形点阵