基于51单片机电子密码锁设计论文Word文件下载.docx
《基于51单片机电子密码锁设计论文Word文件下载.docx》由会员分享,可在线阅读,更多相关《基于51单片机电子密码锁设计论文Word文件下载.docx(35页珍藏版)》请在冰豆网上搜索。
(4)两种情况下可报警:
一是密码输入错误3次,则报警;
二是非正常开门,如破门而入的情况,可通过系统的红外监视装置监测,同时报警,保证了系统的安全性。
系统工作时,用户通过按键输入4位密码,单片机将输入密码与设定密码进行比较,若密码正确,则发出开锁信号,将门打开,系统不报警;
若密码不正确,则有相应的指示灯闪动,并要求重新输入密码,重新输入密码的次数不能超过3次,若3次输入的密码都不正确,则发出报警信号。
2.系统设计
2.1系统总设计结构图
图2-1系统总设计结构图
本设计由主控芯片51单片机,单片机时钟电路,键盘,和开锁电路组成。
单片负责控制整个系统的执行过程。
2.2.开锁机构设计
通过单片机送给开锁执行机构,电路驱动电磁锁吸合,从而达到开锁的目的。
本设计通过P3.0接一个3极管驱动继电器打开电磁阀线圈实现开关门。
密码正确
图2-2密码锁开锁机构示意图
当用户输入的密码正确而且是在规定的时间及次数输入之内,单片机便输出开门信号,送到开锁驱动电路,然后驱动电磁锁,达到开门的目的。
2.2.1主控芯片AT89C51单片机的简介
AT89C51是一种带4K字节闪烁可编程可擦除只读存储器(FPEROM—FalshProgrammableandErasableReadOnlyMemory)的低电压,高性能CMOS8位微处理器,俗称单片机。
单片机的可擦除只读存储器可以反复擦除100次。
该器件采用ATMEL高密度非易失存储器制造技术制造,与工业标准的MCS-51指令集和输出管脚相兼容。
由于将多功能8位CPU和闪烁存储器组合在单个芯片中,ATMEL的AT89C51是一种高效微控制器。
主要特性:
·
与MCS-51兼容
4K字节可编程闪烁存储器
寿命:
1000写/擦循环
数据保留时间:
10年
全静态工作:
0Hz-24MHz
三级程序存储器锁定
128×
8位内部RAM
32可编程I/O线
两个16位定时器/计数器
5个中断源
可编程串行通道
低功耗的闲置和掉电模式
片内振荡器和时钟电路
管脚说明:
VCC:
供电电压。
GND:
接地。
P0口:
P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。
当P1口的管脚第一次写1时,被定义为高阻输入。
P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。
P1口:
P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。
P1口管脚写入1后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。
P2口:
P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。
并因此作为输入时,P2口的管脚被外部拉低,将输出电流。
这是由于内部上拉的缘故。
P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。
在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。
P3口:
P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。
当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。
作为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的缘故。
P3口也可作为AT89C51的一些特殊功能口,如下表所示:
P3.0RXD(串行输入口)
P3.1TXD(串行输出口)
P3.2/INT0(外部中断0)
P3.3/INT1(外部中断1)
P3.4T0(记时器0外部输入)
P3.5T1(记时器1外部输入)
P3.6/WR(外部数据存储器写选通)
P3.7/RD(外部数据存储器读选通)
P3口同时为闪烁编程和编程校验接收一些控制信号。
RST:
复位输入。
当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。
ALE/PROG:
当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。
在FLASH编程期间,此引脚用于输入编程脉冲。
在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。
因此它可用作对外部输出的脉冲或用于定时目的。
然而要注意的是:
每当用作外部数据存储器时,将跳过一个ALE脉冲。
另外,该引脚被略微拉高。
如果微处理器在外部执行状态ALE禁止,置位无效。
/PSEN:
外部程序存储器的选通信号。
在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。
但在访问外部数据存储器时,这两次有效的/PSEN信号将不出现。
/EA/VPP:
当/EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。
注意加密方式1时,/EA将内部锁定为RESET;
当/EA端保持高电平时,此间内部程序存储器。
XTAL1:
反向振荡放大器的输入及内部时钟工作电路的输入。
XTAL2:
来自反向振荡器的输出。
图2-3AT89C51芯片图
3系统硬件设计
3.1键盘设计
为了使本电路更加简洁,本电子锁的密码锁采用简单易学但不为多数人知道的摩期码作为电路的密码输入。
键盘硬件设备只需要一个按即可实现密码的输入与更改。
关于摩斯码的介绍如下:
摩斯密码是20世纪使用较为广泛的电报传输使用的一种编码。
电报最早是由美国的摩尔斯在1844年发明的,故也被叫做摩尔斯电码。
它由一个输入按键在输入时按住的间隔时间长短组成来决定你的输入:
短促的点信号"
."
,读"
嘀"
(Di);
保持一定时间的长信号"
—"
嗒"
(Da)。
间隔时间:
"
嘀"
1t;
嗒"
3t;
滴嗒"
间1t;
字母间3t;
字间5t。
表3-1字符—摩斯码对照表
字符
摩斯码
A
._
M
__
Y
_.__
B
_...
N
_.
Z
__..
C
_._.
O
___
1
.____
D
_..
P
.__.
2
..__
E
.
Q
__._
3
...__
F
.._.
R
._.
4
...._
G
__.
S
...
5
.....
H
....
T
_
6
_....
I
..
U
.._
7
__...
J
.___
V
..._
8
___..
K
_._
W
.__
9
____.
L
._..
X
_.._
_____
注:
摩斯码用在数字电路中“-”表示1,“.”表示0,如0翻译成二进制数为11111H,十六进制数为1FH。
本电路设计只取0~9数字作密码有效数字,如果输入其它字符则无效。
表3-2本设计用到的数字的摩斯码和二进制对照
数字
11111
01111
00111
00011
00001
00000
10000
11000
11100
11110
2进制
3.2系统电路设计:
本系统电路主芯片AT89C51,晶振和两个电容组成的时钟脉冲,一个电阻和一个电解电容和一个按键组成的复位电路,一个8段数码管构成的密码显示器,一个蜂鸣器,5个LED,一个NPN三极管加上一个继电器组成的驱动电路构成了系统电路。
3.2.1晶振时钟电路
单片机XIAL1和XIAL2分别接30PF的电容,中间再并个12MHZ的晶振,形成单片机的晶振电路。
图3-1晶振电路
3.2.2复位电路设计
图3-2复位电路
3.2.3串口引脚功能介绍
单片的P1口外接1位8段数码管,作为密码输入显示器;
INT0外接蜂鸣器,当INT0被置0时,蜂鸣器发出声音;
P0口外接发光二极管用作系统工作状态提示。
3.2.4其它引脚
ALE引脚悬空,复位引脚接到复位电路、VCC接电源、VSS接地、EA接电源
3.3电路图的绘制
用PROTEL99SE绘制的完整电路图如下:
图3-3系统电路图
八段数码管显示你的摩斯按键是否正确对应你要输入的数字密码。
由于采取上电设置密码的编程方法复位键即密码修改键设置在门后,要打开门才能修改密码。
设置密码后若输入密码不对的前两次5秒报警,最后一次10分钟报警,摩斯按发错误除外(但有两秒报警,并且须全部密码重新输入)。
本电路设置四位密码,由于每位数字键均由五位摩斯码构成则要输入20次摩斯码键!
!
p0.0(绿色)“滴”显示,p0.2(黄色)“嗒”音显示,p0.4(红色)摩斯码按法错误或密码错误,p0.6(蓝色)表示该电路已设置了密码,等待输入密码进行比较。
PROTEL绘制的PCB板:
图3-4系统PCB板
PROTEL系统3D仿真:
图3-5系统3D仿真模型
3.3.1PROTEL99SE简介:
Protel99SE是Protel公司近10年来致力于Windows平台开发的最新结晶,能实现从电学概念设计到输出物理生产数据,以及这之间的所有分析、验证和设计数据管理。
因而今天的Protel最新产品已不是单纯的PCB(印制电路板)设计工具,而是一个系统工具,覆盖了以PCB为核心的整个物理设计。
最新版本的Protel软件可以毫无障碍地读Orcad、Pads、Accel(PCAD)等知名EDA公司设计文件,以便用户顺利过渡到新的EDA平台。
Protel99SE共分5个模块,分别是原理图设计、PCB设计(包含信号完整性分析)、自动布线器、原理图混合信号仿真、PLD设计。
以下介绍一些Protel99SE的部分最新功能:
◆可生成30多种格式的电气连接网络表;
◆强大的全局编辑功能;
◆在原理图中选择一级器件,PCB中同样的器件也将被选中;
◆同时运行原理图和PCB,在打开的原理图和PCB图间允许双向交叉查找元器件、引脚、网络
◆既可以进行正向注释元器件标号(由原理图到PCB),也可以进行反向注释(由PCB到原理图),以保持电气原理图和PCB在设计上的一致性;
◆满足国际化设计要求(包括国标标题栏输出,GB4728国标库);
*方便易用的数模混合仿真(兼容SPICE3f5);
◆支持用CUPL语言和原理图设计PLD,生成标准的JED下载文件;
*PCB可设计32个信号层,16个电源-地层和16个机加工层;
◆强大的“规则驱动”设计环境,符合在线的和批处理的设计规则检查;
◆智能覆铜功能,覆铀可以自动重铺;
◆提供大量的工业化标准电路板做为设计模版;
◆放置汉字功能;
◆可以输入和输出DXF、DWG格式文件,实现和AutoCAD等软件的数据交换;
◆智能封装导航(对于建立复杂的PGA、BGA封装很有用);
◆方便的打印预览功能,不用修改PCB文件就可以直接控制打印结果;
◆独特的3D显示可以在制板之前看到装配事物的效果;
◆强大的CAM处理使您轻松实现输出光绘文件、材料清单、钻孔文件、贴片机文件、测试点报告等;
◆经过充分验证的传输线特性和仿真精确计算的算法,信号完整性分析直接从PCB启动;
◆反射和串扰仿真的波形显示结果与便利的测量工具相结合。
由于资金和设备限制,以上PCB电路设计过程属于理论化,只作为电路板设计的一个流程。
本电路的实物模型,本人还是采用万用电路板来完成。
3.4元器件采购
1.元器件清单
表3-3元器件清单
原件名称
备注
单片机
AT89C51
电阻R1,R2
10K,100K各一只
电解电容C3
100F
无极电容C1,C2
30VF
数码管
一只
5V蜂鸣器
晶振
12MHZ
三极管9014
一个
按健S1,S2
各一个
12V继电器
LEDD1,D2,D3,D4
绿,黄,红,蓝各一个
2极管4004
1只
万能电路板
1块
经采购继电器没有买到,所以原电路的输出电路3极管的继电器改为LED灯,只要电路IC经密码输入后能点亮LED灯则电路设计要求达到。
3.5电路焊接
1.焊接所需工具
工具名称
数量
焊烙铁50W
带松香焊丝
若干
万用表
表3-4焊接所需工具
电路焊接实物图如下:
图3-6电路正面接线实物图
图3-7电路背面接线实物图
4.软件设计
4.1系统软件设计整体思路
一个应用系统要完成各项功能,首先必须有较完善的硬件作保证。
同时还必须得到相应设计合理的软件的支持,尤其是微机应用高速发展的今天,许多由硬件完成的工作,都可通过软件编程而代替。
甚至有些必须采用很复杂的硬件电路才能完成的工作,用软件编程有时会变得很简单,如数字滤波,信号处理等。
因此充分利用其内部丰富的硬件资源和软件资源,采用与C51系列单片机相对应的51汇编语言和结构化程序设计方法进行软件编程。
程序设计语言有三种:
机器语言、汇编语言和高级语言。
机器语言是机器唯一能“懂”的语言,用汇编语言或高级语言编写的程序(称为源程序)最终都必须翻译成机器语言的程序(成为目标程序),计算机才能“看懂”,然后逐一执行。
高级语言是面向问题和计算过程的语言,它可通过于各种不同的计算机,用户编程时不必仔细了解所用的计算机的具体性能与指令系统,而且语句的功能强,常常一个语句已相当于很多条计算机指令,于是用高级语言编制程序的速度比较快,也便于学习和交流,但是本系统却选用了汇编语言。
原因在于,本系统是编制程序工作量不大、规模较小的单片机微控制系统,使用汇编语言可以不用像高级语言那样占用较多的存储空间,适合于存储容量较小的系统。
4.2系统软件设计流程图
图4-1系统程序设计结构图
5程序调试
把也写好的汇编语言程序的载入软件调试工具,检查软件是否有设法错误,再根据软件提示对本程序进行修改,直到没有错误再生成单片机能运行的机器码,再用51开发板或其它单怎机写入工具把机器码写入单片机进行实际的程序调试,根据实际情况再对程序的不足加以修改,直到满足设计要求。
5.1程序调试用到的软件及工具
调试本程序需要用到KEILC51,及51开发板一块及其配套的下载烧录软件
5.2KEILC51简介
KeilC51是美国KeilSoftware公司出品的51系列兼容单片机C语言软件开发系统,与汇编相比,C语言在功能上、结构性、可读性、可维护性上有明显的优势,因而易学易用。
用过汇编语言后再使用C来开发,体会更加深刻。
KeilC51软件提供丰富的库函数和功能强大的集成开发调试工具,全Windows界面。
另外重要的一点,只要看一下编译后生成的汇编代码,就能体会到KeilC51生成的目标代码效率非常之高,多数语句生成的汇编代码很紧凑,容易理解。
在开发大型软件时更能体现高级语言的优势。
C51工具包的整体结构:
uVision与Ishell分别是C51forWindows和forDos的集成开发环境(IDE),可以完成编辑、编译、连接、调试、仿真等整个开发流程。
开发人员可用IDE本身或其它编辑器编辑C或汇编源文件。
然后分别由C51及A51编译器编译生成目标文件(.OBJ)。
目标文件可由LIB51创建生成库文件,也可以与库文件一起经L51连接定位生成绝对目标文件(.ABS)。
ABS文件由OH51转换成标准的Hex文件,以供调试器dScope51或tScope51使用进行源代码级调试,也可由仿真器使用直接对目标板进行调试,也可以直接写入程序存贮器如EPROM中。
5.3调试过程
首先打开KEILC51主程序,新建工程,新建文本框写入程序,保存,检查是否有语法错误,经反复检查无误后汇编,生成51单片机可执行的HEX文件。
然后用51开发板相匹配的烧录软件把HEX文件写入单片机。
图5-1keilc51调试介面
图5-2单片机烧录软件介面
6设计总结与展望
实践是检验真理的唯一标准,当然也是检验学习成果的标准。
在经过一段时间的学习之后,我们需要了解自己的所学应该如何应用在实践中,因为任何知识都源于实践,归于实践,所以要将所学的知识在实践中来检验。
在做毕业设计期间,在老师的指导下,通过自身的不断努力,无论是思想上,学习上,都取得了长足的发展和巨大的收获,现将工作总结如下:
思想上,学会了用科学的精神去解决问题。
很多事情看起来是很简单的问题,但实际做起来去会发现有许多奥妙!
这是因为其中蕴含着许多科学的问题。
运用科学的方法去解决问题,这是我这次实训给我带来的思想上的改变。
学习上,使自已在大学所以的知识在这次得到实践,学到一些书本上无法学到的经验,对电子元件有了进一步的认识。
电子锁是信息化时代发展的产物,应时而生,我相信随着科技的不断发展,将来的电子锁一定更加完美,更加人性化,更加便宜,更加安全。
致谢
在本次论文设计过程中,刘老师对该论文从选题,构思到最后定稿的各个环节给予细心指引与教导,使我得以最终完成毕业论文设计,在此表示衷心的感谢。
此外在学习中,老师严谨的治学态度、丰富渊博的知识、敏锐的学术思维、精益求精的工作态度以及侮人不倦的师者风范是我终生学习的楷模。
另外在完成毕业设计的过程中,还得到众多朋友的关心支持和帮助,在此,谨向老师同学和朋友致以衷心的感谢和崇高的敬意!
最后,我要向百忙之中抽时间对本文进行审阅,评议和参与本人论文答辩的各位老师表示感谢
参考文献
[1]李朝青.单片机原理及接口技术(简明修订版)[M].北京:
北京航空航天大学出版社,1998
[2]李全利.单片机原理及接口技术[M].高等教育出版社,2003
[3]PROTEL99SE电路设计与制板[M].机械工业出版社,2007
[4]杨将新,李华军,刘到骏等.单片机程序设计及应用(从基础到实践)[J].电子工业出版社,2006
[5]StevenF.Barrett.DaneilJ.Pack.EmbeddedSystem[M].北京:
电子工业出版社,2006
[6]周立功.LPC900系列Flash单片机应用技术[J].北京航空航天大学出版社,2004
[7]黄智伟.全国大学生电子设计竞赛训练教程[M].北京:
电子工业出版社,2005
附录
本设计的程序:
hc0equ4ah;
延时缓存区
hc1equ4bh
hc2equ4ch
hc3equ4dh
hc4equ4eh
xs_0equ50h;
显示缓存区
xs_1equ51h
xs_2equ52h
xs_3equ53h
xs_4equ54h
xs_5equ55h
xs_6equ56h
xs_7equ57h
xs_8equ58h
xs_9equ59h
ps1equ5ah;
设置密码