《基于单片机的电子密码锁设计(共32页).doc》由会员分享,可在线阅读,更多相关《基于单片机的电子密码锁设计(共32页).doc(31页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上嵌入式系统项目实践课程报告题 目 基于单片机的电子密码锁设计 团队成员 专 业 网络工程 指导教师 2014年10月9日目录基于单片机的电子密码锁设计摘要:随着信息技术的不断发展,信息化时代也逐步进入普通家庭,人们对个人的信息安全以及隐私等私密信息的安全要求不断提高,传统的机械锁已经不能满足要求。针对此现状设计一款安全可靠廉价的电子密码锁。该设计以AT89C51为主控芯片,带有一个密码输入键盘、外围时钟复位电路、存储单元24C04、显示单元1602LCD,通过LED灯的亮与灭表示电子锁的锁闭与打开。利用单片机灵活的编程设计和丰富的IO端口,能实现密码锁的基本功能。为了
2、提高可读性采用了1602作为显示单元,使用户对密码锁的运行情况一目了然。该系统经软硬件测试,达到要求,系统运行良好。 关键词:单片机;AT89C51;1602LCD;24C04;电子密码锁1 绪论1.1选题背景在人们的生活中,财产与人身安全是被一直关注的问题,于是“锁”也就与人们的生活密不可分了,无论在何地,我们都能看到“锁”的身影,但随着社会的发展,传统的机械锁越来越不能满足人们的生活需求了,传统的机械锁由于其构造的简单,被撬的事件屡见不鲜。锁具发展到现在已有若干年的历史了,人们对它的结构、机理也研究得很透彻,因此,不用钥匙就能打开的方法和工具也层出不穷。为了应对这种情况,电子密码锁也就被发
3、明出来了,相比传统的机械锁,电子密码锁具有更高的安全性。1.2研究意义电子锁可以在日常生活和现代办公中、住宅与办公室的安全防范、单位的文件档案、财务报表以及一些个人资料的保存等多种场合使用,大大提高了主人物资的安全性。此次项目实践选择基于单片机的电子密码锁设计题目,采用存储单元24C04和显示单元1602LCD来进行设计。单片机技术是智能化检测与控制领域应用非常普及并且具有很大潜力的技术。论文阐述一个基于单片机的液晶显示电子密码锁的设计与实现。系统采用美国Atmel公司的AT89C51单片机作为系统核心,用串行的24C04作为存储器,液晶显示器LCD1602作为输出设备显示系统提示信息,4*4
4、矩阵薄膜键盘作为输入设备,配合蜂鸣器、继电器等电路构成整个系统硬件;系统软件采用汇编语言编写。设计的系统液晶显示,密码修改方便,具有报警、锁定等功能,使用便捷简单,符合住宅、办公用锁需求,具有一定的实用价值.而且使用AT89C51单片机价格相对低廉,成本较低,便于推广。1.3内容与结构本系统设计实现一个基于单片机控制的电子密码锁。该系统能够实现上锁、开锁、修改开锁密码和报警功能,用串行的24C04作为存储器,液晶显示器LCD1602作为输出设备显示系统提示信息。该文档主要包括五个部分,第一部分绪论,主要包括选题背景、研究意义和内容与结构;第二部分系统整体设计方案,主要包括相关知识介绍和系统总体
5、结构设计;第三部分硬件电路,主要包括单元电路设计和系统总硬件电路图,其中单元电路设计包括单片机最小系统模块,24C04存储电路模块,1602LCD数码管显示电路和矩阵键盘电路设计模块;第四部分软件模块设计,主要包括系统开发工具使用和系统主要开发流程和各软件设计模块;第五部分结果分析,主要包括测试过程和测试结果分析。2 系统整体设计方案2.1相关知识介绍2.1.1 AT89C51引脚功能描述AT89C51是这几年我国非常流行的单片机,由美国ATMEL公司生产,是低电压,高性能CMOS8位单片机,片内含4kbytes的可反复擦写的只读程序存储器(PEROM)和128bytes的随机存取数据存储器(
6、RAM),器件采用ATMEL公司的高密度、非易失性存储技术生产,兼容标准MCS-51指令系统,片内置通用8位中央处理器(CPU)和Flash存储单元。其中的40个引脚大致可以分为4类:电源、时钟、控制和I/O引脚。(1)电源:VCC为芯片电源端,一般为+5V,GND为接地端;(2)时钟:XTAL1为晶体振荡电路的反相输入端,XTAL2为晶体振荡电路的输出端;(3)控制线:MCS-51单片机的控制线有4根,其中3根是复用线,具有两种功能。ALE/PROG为地址锁存允许/编程脉冲信号端,PSEN为外部ROM读选通信号,RST为复位引脚;EA/VPP为内外ROM选择/EPROM编程电源;(4)I/O
7、引脚:MCS-51单片机共有4个8位并行I/O端口,共32个可编程I/O引脚。其外形引脚如图2-1所示: 图2.1 AT89C51实物图(左)及其引脚图(右)2.1.2 LCD1602性能描述LCD1602是工业字符型液晶,能够同时显示16x02即32个字符,是一种专门用来显示字母、数字、符号等的点阵型液晶模块,字符型LCD通常有14条引脚线或16条引脚线的LCD,多出来的2条线是背光电源线VCC(15脚)和地线GND(16脚),其控制原理与14脚的LCD完全一样6。LCD引脚图如下图2.6所示: 图2.2 LCD1602功能引脚图2.1.3 24C04性能描述 24C04是采用铁电技术生产的
8、EEPROM,掉电后数据不丢失。相比传统的EEPROM具有寿命长,读写速度快的优点,采用与外界通讯,容量应该是512字节。主要用于存储掉电后需要保存的数据。24C04存储电路如图2.3所示:图2.3 24C04存储电路2.2系统总体设计此设计的主要内容与任务如下:(1)设计一单片机控制的智能报警系统,通过按键输入密码,并用LCD显示相关信息;(2)密码可由键盘设置,键盘有数字键、还有确认按键;(3)密码可通过按键修改;(4)输入字符时,LCD上显示“*”号,若密码正确,则可以修改密码;(5)系统设置默认初始密码,且可以修改,修改后系统按新密码进行操作。依据设计的要求,可以得到系统软件模块图,如
9、图2.4所示: 基于单片机的电子密码器 时钟震荡电路模块矩阵键盘输入模块LCD显示模块密码存储模块蜂鸣器报警电路模块 图2.4 系统的软件模块图 3硬件电路 用单片机做主机运算器,能进行密码修改和管理员密码设置,可复位,设置有退出键、管理员模式键、设定键、删除键和确定键。LCD在开锁前显示you password,然后根据密码正确与否显示出相应的提示。本设计初始密码为,密码输入正确后,可以修改密码,密码个数可以是0-9的数字。采用24C04存储密码,有掉电保护功能,本设计采用4*4的矩阵键盘作为输入,AT89C51单片机作为主机,二极管指示灯和喇叭组成发声系统。根据系统拟达到的总体功能得到系统
10、整体框图如图3.1所示:LCD显示键盘输入AT89C51蜂鸣器报警与开锁电路掉电存储电路图3.1系统整体框图3.1单元电路设计 要实现基于单片机电子密码锁的功能。硬件设计包括单片机最小系统的设计,1602LCD数码管显示电路设计,矩阵键盘电路设计和系统总电路的设计。3.1.1单片机最小系统 单片机最小系统都是由组成单片机应用系统所必需的一些部件和电路构成的。无论应用系统要完成什么功能,这些部件和电路都是必须的。一个单片机应用系统至少有:单片机芯片、保证单片机正常工作必须要有电源、产生时钟信号的晶体振荡器,还需要能使单片机复位的电路等。单片机最小系统如图3.2所示: 图3.2单片机最小系统3.1
11、.2 1602LCD数码管显示电路 1602LCD液晶显示器是一种字符点阵式LCD显示器模块。它不仅能够显示阿拉伯数字,而且还能够显示特殊的符号,以及英文字母(即英文语句提示信息),因此其用途比较灵活,应用比较广泛,当然价格也较高。单片机AT89C51从接收器得到的数据运算程序后,结果传送给1602LCD数据端并在液晶屏上显示出。显示电路如图3.3所示: 图3.3 1602LCD数码管显示电路3.1.3矩阵键盘电路 矩阵式键盘又叫行列式键盘。用I/O接口线组成行、列结构,键位设置在行、列的交点上。例如本设计4*4的行、列结构可组成16个键盘,比一个键位用一根I/O口线的独立式键盘少了一半的I/
12、O接口线。而且键位越多,情况越明显。因此,在按键比较多时,往往采用矩阵式键盘。矩阵式键盘的按键识别方法有“行扫描法”。行扫描法又称为逐行(或列)扫描查询法,是一种最常用的按键识别方法,介绍过程如下。 (1) 判断键盘中有无键按下将全部行线Y0-Y3置低电平,然后检测列线的状态。只要有一列的电平为低,则表示键盘中有键被按下,而且闭合的键位于低电平线与4根行线相交叉的4个按键之中。若所有列线均为高电平,则键盘中无键按下。 (2)判断闭合键所在的位置在确认有键按下后,即可进入确定具体闭合键的过程。其方法是:依次将行线置为低电平,即在置某根行线为低电平时,其它线为高电平。在确定某根行线位置为低电平后,
13、再逐行检测各列线的电平状态。若某列为低,则该列线与置为低电平的行线交叉处的按键就是闭合的按键。 矩阵键盘电路如图3.4所示: 图3.4 矩阵键盘电路图3.2系统总硬件电路图各模块组合之后的总体硬件电路图如下图3.5所示: 图3.5总体硬件电路图 4 软件模块设计4.1系统开发工具使用本系统使用keil软件,打开软件后的界面,如下图4.1所示,图4.1软件运行界面单击Project选择New Project.,弹出Create New Project对话框,图4.2新建系统工程 选择工程文件要存放的路径 ,输入工程文件名, 最后单击保存, 图4.3设置工程路径 在弹出的对话框中选择 CPU 厂商
14、及型号,选择好 Atmel 公司的 89C51 后 , 单击确定,图4.4选择芯片厂商和型号新建一个 C51 文件 , 点击file菜单下的NEW,或单击左上角的 New File快捷键如图4.5,图4.5新建文件 保存新建的文件,单击SAVE,在出现的对话框中输入保存文件名LCD_18b20.c(注意后缀名必须为.C),再单击“保存”, 保存好后把此文件加入到工程中方法如下 : 用鼠标在 Source Group1 上单击右键 , 然后再单击 Add Files to Group Source Group 1 如图4.6,图4.6将文件添加到工程中在编辑框里输入如下代码 ,到此我们完成了工程
15、项目的建立以及文件加入工程 , 现在我们开始编译工程,即单击快捷键或单击Project/Rebuild all the files, 如果在错误与警告处看到 0 Error(s) 表示编译通过。生成 .hex 烧写文件,先单击Options for Target,如图4.7, 图4.7生成.hex 在下图中,我们单击 Output, 选中 Create HEX Fi。再单击“确定”,然后我们必须再次编译才能产生HEX文件 图4.8对系统进行配置4.2系统开发流程图程序主要完成的任务,开始时LCD显示“Your Password”提示输入密码,输入密码后按确认键,系统会将所输入的密码与系统密码进
16、行对比,如果输入正确则显示“Unlock OK”开锁,然后可以选择上锁或者修改密码,如果密码错误则显示“Error”,如果连续输入三次错误密码系统会发出报警声音,程序流程图如图4.9所示:图4.9 系统总体流程图4.3系统软件设计模块4.3.1键盘扫描软件设计 在按键当中,有与输入、开锁、清除、设置、确认的程序相对应的按键,并按顺序与输入的数相比较,当输入正确时,进入密码程序,错误时进行清除,输入两次新密码正确时,可进行重新设置密码,最后确认程序。按键的检测主要是通过查询的方法来实现的,利用按键进行密码的输入及设置。 图4.10 键盘扫描流程图4.3.2 24C04读写操作的软件设计图4.11
17、 24C04读写操作流程图4.3.2 24C04读写操作的软件设计图4.12开锁流程图4.3.4修改密码软件设计图4.13 修改密码流程图5 结果分析程序编写完之后,单击Rebuild()按钮,进行编辑,单击build()按钮,进行编译,将.hex文件下载到ATC89C51开发板中。图5.1 配置电路图参数单击左下角的中的按钮进行仿真。5.1电子密码锁开锁和上锁 在矩阵键盘上输入初始密码,并点击开锁按钮,如果输入密码错误,则LCD显示“ERROR!”,无法开锁;若输入正确,则显示“Unlock OK!”,表示开锁成功,如图5.2所示: 图5.2 开锁后LCD显示图 再按下上锁按键后,电子密码锁
18、重新上锁,需要重新输入开锁密码才可开锁,当三次输入错误密码时,蜂鸣器会发出响声报警。5.2修改电子密码锁密码 在已经开锁的状态下,按下输入新密码按钮,可重新输入密码,设置成你想要改的密码,再按下保存新密码按钮,新密码就设置成功了,这时开锁需要输入新密码了,如图5.3所示 图5.3电子密码锁修改密码此次项目实践的基于单片机电子密码锁设计比较成功,能实现开锁上锁、修改密码、报警防盗等功能。结论本次项目实践过程中,对我所学的所有的嵌入式知识进行一个总结性的复习,特别是对AT89C51单片机方面的知识有了更深的了解。同时也巩固了对LCD1602,数据存储等方面的知识,为我以后的学习以及工作奠定了一定的
19、专业基础。在这次设计中,遇到了一些设计上的难题,通过查阅相关图书资料和询问同学帮助解决了难题。参考文献1祁伟, 杨亭.单片机C51程序设计教程与实验M. 北京航空航天大学出版社,2006.2刘文涛.单片机语言C51典型应用设计M. 人民邮电出版社,2005.3谭浩强.C程序设计(第三版)M. 清华大学出版社,2005.4沈德金.M.北京航空航天大学出版社, 1990.5赖麒文. M., 2002.6余永权.M. 电子工业出版社,2003.7张艳丽,杨仁弟.数字温湿度传感器SHT11及其应用J.工矿自动化,2007.6第3期.8沈庆阳.8051单片机实践与应用M.清华大学出版社2004 .9高卫
20、东.51单片机原理与实践(C语言版)M.北京航空航天大学出版社,2011.10蒋辉平,周国雄.基于Protues的单片机系统设计与仿真实例M. 机械工业出版社,2009.附录:程序代码:#include #include #define uchar unsigned char#define unit unsigned intuchar Pre_KeyNo = 16, KeyNo = 16;uchar code Title_Text = Your Password.;uchar DSY_BUFFER10 = ;uchar UserPassword10 = ;void LCD_Init();voi
21、d Display_String(uchar * str,uchar LineNo);void IIC_24C04_Init();uchar RecString(uchar Slave,uchar Subaddr,uchar *Buffer,uchar N);uchar SendString(uchar Slave,uchar Subaddr,uchar *Buffer,uchar N);uchar Keys_Scan();sbit LED_OPEN = P27;void DelayMS(int x ) uchar i; while (x-) for (i = 0;i120;i+);void
22、Clear_Password() UserPassword0 = 0; DSY_BUFFER0 = 0;void main() uchar i = 0; uchar IIC_Password10; uchar IS_Valid_User = 0; P0 = P1 = P2=0xFF; TMOD = 0X02; TH0 = 175; TL0 = 175; TR0 = 1; DelayMS(10); LCD_Init(); IIC_24C04_Init(); Display_String(Title_Text,0x00); RecString(0xa0,0,IIC_Password,6); IIC
23、_Password6 = 0; while(1) P1 = 0xF0; if(P1 !=0xF0) KeyNo =Keys_Scan(); if(Pre_KeyNo !=KeyNo) if(i10) switch (KeyNo) case 0: case 1: case 2: case 3: case 4: case 5: case 6: case 7: case 8: case 9: if(i=0) Display_String( ,0x40); UserPasswordi=KeyNo + 0; UserPasswordi+1=0; DSY_BUFFERi = *; DSY_BUFFERi+
24、1=0; Display_String(DSY_BUFFER,0X40); i+; break; case 10: if (strcmp(UserPassword,IIC_Password) = 0) LED_OPEN = 0; Clear_Password(); Display_String(Unlock OK! ,0x40); IS_Valid_User = 1; else LED_OPEN = 1; Clear_Password(); Display_String(ERROR ! ,0x40); IS_Valid_User = 0; i=0; break; case 11: LED_OP
25、EN = 1; Clear_password(); Display_String(Title_Text,0x00); Display_String( ,0x40); i=0; IS_Valid_User = 0; break; case 12: if(!IS_Valid_User) Display_String(No rights !,0x40); else i=0; Display_String(New Password: ,0x00); Display_String( ,0x40); break; case 13: if(!IS_Valid_User ) Display_String(No
26、 rights !,0x40);else SendString(0xa0,0,UserPassword, 6); RecString(0xa0,0,IIC_Password, 6); IIC_Password6 = 0; i=0; Display_String(Title_Text,0x00); Display_String(Password Saved! ,0x40); break; case 14: i=0; Clear_Password(); Display_String( ,0x40); Pre_KeyNo = KeyNo; DelayMS(100); #include #includ
27、e #define uchar unsigned char #define unit unsigned int #define Delay4us(); _nop_();_nop_(); _nop_();_nop_(); sbit SCL = P32; sbit SDA = P33; void Start() SDA = 1;SCL = 1;Delay4us();SDA = 0;Delay4us();SCL = 0; void Stop()SDA =0;SCL =1;Delay4us();SDA = 1;Delay4us();SCL=0; void IIC_24C04_Init() SCL =
28、0; Stop(); void ACK() SDA =0;SCL =1;Delay4us();SCL = 0;SDA=1; void No_ACK() SDA =1;SCL =1;Delay4us();SCL = 0;SDA=0; uchar RecByte() uchar i,rd; rd = 0x00; SDA = 1; for(i=0;i8;i+) SCL =1 ;rd=1; rd |=SDA;Delay4us();SCL = 0;Delay4us(); SCL=0; Delay4us(); return rd; uchar SendByte(uchar wd) uchar i; bit
29、 ack0; for(i=0;i8;i+) SDA=(bit)(wd & 0x80); _nop_();_nop_();SCL = 1;Delay4us();SCL = 0;wd=1; Delay4us(); SDA = 1;SCL = 1; Delay4us(); ack0 = !SDA; SCL = 0; Delay4us(); return ack0; uchar SendString(uchar Slave,uchar Subaddr,uchar *Buffer,uchar N) uchar i; Start(); if(!SendByte(Slave) return 0; if(!S
30、endByte(Subaddr) return 0; for(i=0;iN;i+) if (!SendByte(Bufferi) return 0; Stop(); return 1; uchar RecString(uchar Slave,uchar Subaddr,uchar *Buffer,uchar N) uchar i; Start(); if(!SendByte(Slave) return 0; if(!SendByte(Subaddr) return 0; Start(); if(!SendByte(Slave+1) return 0; for(i=0;iN-1;i+) Buff
31、eri = RecByte(); ACK(); BufferN-1 = RecByte(); NO_ACK();Stop(); return 1; #include #define uchar unsigned char #define unit unsigned int void DelayMs(unit x); uchar Keys_Scan() uchar Tmp,KeyNo = 0; P1=0x0F; DelayMs(1); Tmp = P1 0x0F; switch (Tmp) case 1: KeyNo = 0;break; case 2: KeyNo = 1;break; case 4: KeyNo = 2;break; case 8: KeyNo = 3;break; default: KeyNo = 16; P1 = 0X0F; DelayMs(1); Tmp = P1 4 0x0F; switch (Tmp) case 1: KeyNo += 0; break; case 2: KeyNo += 4; break; case 4: KeyNo += 8; break; case 8: KeyNo += 12; return KeyNo; 专心-专注-专业
限制150内