基于51单片机的无线电子密码锁课程设计Word格式.docx
《基于51单片机的无线电子密码锁课程设计Word格式.docx》由会员分享,可在线阅读,更多相关《基于51单片机的无线电子密码锁课程设计Word格式.docx(20页珍藏版)》请在冰豆网上搜索。
无线电子密码锁分为两个主要功能模块:
51单片机模块,蓝牙实现模块。
这两个模块共同工作完成本电路的功能实现。
其中利用AT89C51芯片来实现51单片机模块功能,完成数码管、发光二极管的实现,同时利用HC06蓝牙模块来实现手机远程控制功能。
其设计总框图如图1所示:
无线蓝牙串口通信
主控模块
输入状态显示
AT89C51
手机蓝牙串
——-
开关状态显示
口助手
图1总体方框图
3、2单元模块设计
3、2、1、总电路
其设计的总电路如图2所示:
图2总电路图
其工作原理如下:
通过在51单片机开发板对AT89C52芯片写入程序,建立单片机与蓝牙模块之间的串口通信,并通过手机输入指令输入到蓝牙模块之中,通过程序利用单片机串口将蓝牙与51单片机进行通信,并控制单片机的引脚,从而控制外围电路的LED灯的亮灭与数码管的功能实现。
3、2、251单片机系统
单片机最小系统就是在以MCS-51单片机为基础上扩展,使其能更方便地运用于测试系统中,不仅具有控制方便、组态简单与灵活性大等优点,而且可以大幅度提高被测试的技术指标,从而能够大大提高产品的质量与数量。
单片机以其功能强、体积小、可靠性高、造价低与开发周期短等优点,称为在实时检测与自动
控制领域中广泛应用的器件,在工业生产中称为必不可少的器件,尤其就是在日常生活中发挥的作用也越来越大。
本课题设计主要在MCS-51单片机上扩展I/O口,扩展定时器定时范围,扩展键盘显示接口。
下图为AT89C51芯片引脚图如图3所示:
器■YLEELI
于匚晋才•-T6=r
图389C51芯片引脚图
3、2、3复位及振荡电路
单片机中的复位及振荡电路如图4所示:
图4复位及振荡电路图
复位电路由按键复位与上电复位两部分组成。
按键复位就就是在复位电容上并联一个开关,当开关按下时电容被放电、RST也被拉到高电平,而且由于电容的充电会保持一段时间的高电平来使单片机复位。
MCS51使用11、0592MHz的
晶体振荡器作为振荡源,由于单片机内部带有振荡电路,所以外部只要连接一个晶振与两个电容即可,电容容量一般在15pF至50pF之间。
3、2、4八段数码显示管
单片机中数码管的实现与显示电路如图5所示:
图5数码管电路图
MCS-51单片机包含六个共阴极8段数码管显示器,可以使用动态扫描或者静态显示方式驱动。
八位段选在通过330Q限流后连接在单片机的P0口上。
3、2、5按键及LED电路
单片机中LED灯与按键电路如图6所示:
图6按键及LED电路图
开发板上提供了8个独立LED,由P2口控制,同样采用共阳级接法,所以只有当P2口输出低电平时LED才会点亮。
这样做的主要原因就是因为单片机的低电平驱动能力高。
3、2、6蓝牙模块
HC-06就是主从一体化的蓝牙串口模块,主从可指令切换,指令少于HC-05,使用简单。
(供电电压3、3V~3、6V)主机:
用来搜索从设备,不能被其她设备搜索。
(带白点的蓝牙模块)从机:
用来被搜索的设备,不能主动搜索其她设备。
主从连上以后
就相当于一根串口线使用,这个时候就不分主从,也就就是透传模式。
蓝牙透传模块可以让您原来使用串口的设备摆脱线缆的束缚在10米范围内实现无线串口通
信。
4系统设计
4、1主程序流程图
系统总流程图如图7所示,流程图分析:
首先系统初始化,系统开始运行,当手机输入数字密码时,数码管会以加密的方式显示输入状态,若就是6位密码输入正确,则LED亮起(代表锁打开),否则熄灭。
在LED灯亮起的前提下,可以输入命令'
c'
进入更改密码模式,然后重新输入新密码,此时数码管显示的就是不加密的明文。
输入新密码完成之后输入命令'
(对新密码进行确认,所有的操作均在手机端的
APP中完成。
在手机按键操作之下点击’clos可以直接关闭密码锁,点击’retry能’够重新开始输入密码。
本密码锁能实现掉电密码保存功能,即使断电重启也不会
重新恢复初始密码,大大提高了电子密码锁的实用性与安全性。
而更改密码这一功能就是在高级模式下更改的,一般人即使知道了密码但就是不知道更改密码的命令就是无法更改密码的,安全保障更上一层。
注:
更改密码为此密码锁的高级模式,普通权限下使用的就是“键盘模式”。
数码管显示输入状
态
NO
密码是否正确?
•
----
确认新密码或重新
输入新密码
YES
图7程序流程图
4、2硬件测试
(1)用手机连上HC06模块的蓝牙之后,在手机APP中的键盘模式里面输入
图8输入初始密码的测试结果图
初始密码‘12345’并观察单片机的变化,显示结果如图8所示:
数码管上显示输入密码的状态,6位密码均被用‘—进行加密,从手机APP的图上面可以瞧出输入的密码为‘012345'
码输入正确,数码管下方的一排LED灯亮起。
(2)在手机APP的命令模式中输入‘c在开锁的状态下),设置新密码为321654'
此时新密码设置的过程为明文在数码管上显示。
然后输入d'
对新密码进行确认。
显示结果如图9所示:
图9设置新密码
(3)进入APP键盘模式,点击’clos按钮,关闭密码锁,然后重新掉电启动密码锁输入’01234旧密码,显示结果如图10所示:
图10密码更新之后输入旧密码
可见数码管右下方的LED灯没有亮起,说明输入密码错误
结果如图11所示:
图11输入新密码测试图
由结果可知输入正确的新密码之后可以成功开启密码锁,而原始的密码则不能。
说明密码更改成功。
4、3测试结果分析与结论
在编写程序的时候,需要一定的逻辑思维,同时需要有耐心同时又要细心。
在编译成功后,产生以“*hex”与“*bin”后缀的目标文件。
在下载程序的时候,需要注意的就是,先要将程序下载到AT89C51中再将蓝牙与单片机用杜邦线连接起来。
从硬件测试的结果可以知道,显示功能与所写程序实现的功能基本符合,基本完成了基础的无线电子密码锁设计。
5设计体会
经过多次的反复测试与分析,对电路的原理及功能更加熟悉,同时提高了设计能力与及对电路的分析能力。
同时在软件的编程方面得到更到的提高,对编程能力得到加强,同时对所学的知识得到很大的提高与巩固。
总之,在这次课程设计过程中,我收获了很多,不仅对我以后的学习有很大的帮助,也为将来的人生之路坐了一个很好的铺垫
参考文献
[1]黄辉先、单片机原理及应用[M]、湘潭:
湘潭大学出版社,2013、
附录程序设计
/********************************************************************
无线电子密码锁1312203-30刘武
*********************************************************************
与P1相连的8位发光LED点亮代表锁被打开;
熄灭代表锁被锁上。
程序功能:
本程序结合了24C02存储器的存储功能,可以掉电保存密码。
利用HC-06无线蓝牙模块与手机端的蓝牙进行通信,再通过HC-06的串口与51单片机进行串口通信,从而达到远程开关锁的功能。
远程距离可达5~10米(视场地空旷
程度而定)
1、开锁:
开启设备,从手机端输入密码,当6位密码正确时点亮8位发光LED。
2、更改密码:
只有当开锁(LED亮)后,该功能方可使用。
从手机app进入实时命令模式输入'
(change之后再输入想要更改的密码,最后输入'
d'
确认密码。
3、重试密码:
手机端app的键盘模式”中点击“retry或者进入实时命令模式输入’a'
当设置密码时,设置中途想更改密码,也可按下此键重新设置。
4、关闭密码锁:
手机端app的"
键盘模式"
中点击“close或者进入实时命令模式下输入'
b'
。
*******************************************************************/
#include<
reg52、h>
#include<
intrins、h>
#defineuintunsignedint#defineucharunsignedcharucharold1,old2,old3,old4,old5,old6;
ucharnew1,new2,new3,new4,new5,new6;
//新采集的密码
uchara=16,b=16,c=16,d=16,e=16,f=16;
/送/入数码管显示的变量
ucharwei,key,temp,input;
bitallow,genggai,ok,wanbi,retry,close,on;
//各个状态位
sbitdula=P2A6;
sbitwela=P2A7;
sbitbeep=P2A3;
sbitsda=P2A0;
//IO口定义
sbitscl=P2A1;
unsignedcharcodetable[]=
{0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,
0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00,0x40};
/*****************IIC
芯片24C02存储器驱动程序**************/
voidnop()
{
_nop_();
}
/////////24C02读写驱动程序////////////////////voiddelay1(unsignedintm)
{unsignedintn;
for(n=0;
n<
m;
n++);
voidinit()//24c02初始化子程序
scl=1;
nop();
sda=1;
voidstart()//启动I2C总线
sda=0;
scl=0;
voidstop()//停止I2C总线
voidwritebyte(unsignedcharj)//写一个字节
unsignedchari,temp;
temp=j;
for(i=0;
i<
8;
i++)
{temp=temp<
<
1;
scl=0;
nop();
sda=CY;
//temp左移时,移出的值放入了CY中nop();
〃待sda线上的数据稳定后,将scl拉高
unsignedcharreadbyte()//读一个字节
unsignedchari,j,k=0;
sda=1;
scl=1;
if(sda==1)
j=1;
else
j=0;
k=(k<
1)|j;
return(k);
voidclock()//I2C总线时钟
unsignedchari=0;
while((sda==1)&
&
(i<
255))
i++;
////////从24c02的地址address中读取一个字节数据/////unsignedcharread24c02(unsignedcharaddress){
unsignedchari;
start();
writebyte(0xa0);
clock();
writebyte(address);
clock();
writebyte(0xa1);
i=readbyte();
stop();
delay1(100);
return(i);
//////向24c02的address地址中写入一字节数据info/////voidwrite24c02(unsignedcharaddress,unsignedcharinfo){
start();
writebyte(0xa0);
writebyte(info);
delay1(5000);
/****************
密码锁程序模块*********************/
voiddelay(unsignedchari)
ucharj,k;
for(j=i;
j>
0;
j--)for(k=125;
k>
k--);
voiddisplay(uchara,ucharb,ucharc,uchard,uchare,ucharf){
dula=0;
P0=table[a];
dula=1;
wela=0;
P0=0xfe;
wela=1;
delay(5);
P0=table[b];
P0=0xfd;
wela=1;
delay(5);
P0=table[c];
P0=0xfb;
P0=table[d];
P0=0xf7;
P0=table[e];
P0=0xef;
P0=table[f];
P0=0xdf;
voidkeyscan()〃输入按键扫描模块
if(on)
switch(input)
case'
0'
:
key=0;
wei++;
break;
1'
key=1;
2'
key=2;
3'
key=3;
4'
key=4;
5'
key=5;
break;
6'
key=6;
wei++;
case'
7'
key=7;
8'
key=3;
9'
a'
retry=1;
close=1;
genggai=1;
wei=0;
if(allow)
ok=1;
beep=0;
//delay(500);
beep=1;
on=0;
voidshumima()//对按键采集来的数据进行分配
if(!
wanbi)
switch(wei)
case1:
new1=key;
if(!
allow)a=17;
elsea=key;
case2:
new2=key;
if(a==17)b=17;
elseb=key;
case3:
new3=key;
if(a==17)c=17;
elsec=key;
case4:
new4=key;
if(a==17)d=17;
elsed=key;
case5:
new5=key;
if(a==17)e=17;
elsee=key;
case6:
new6=key;
if(a==17)f=17;
elsef=key;
wanbi=1;
voidyanzheng()//验证密码就是否正确
if(wanbi)//只有当六位密码均输入完毕后方进行验证
if((new1==old1)&
(new2==old2)&
(new3==old3)&
(new4==old4)&
(new5==old5)
(new6==old6))
allow=1;
//当输入的密码正确,会得到allowe置1
voidserial_init()
SCON=0X50;
TMOD=0X20;
TH1=0XFD;
TL1=0XFD;
TR1=1;
EA=1;
ES=1;
voidmain()
init();
//初始化24C02
old1=read24c02(110);
old2=read24c02(111);
old3=read24c02(112);
old4=read24c02(113);
old5=read24c02(114);
old6=read24c02(115);
serial_init();
//初始化串口中断
while
(1)
keyscan();
shumima();
yanzheng();
if(allow)//验证完后,若allow为1,则开锁
P1=0x00;
genggai)
wanbi=0;
if(genggai)//当更改密码键('
)被按下,genggai会被置1
if(allow)//若已经把锁打开,才有更改密码的权限
while(!
wanbi)//当新的六位密码没有设定完则一直在这里循环{
if(retry|close)//而当探测到重试键或者关闭密码锁键被
按下时,则跳出
{wanbi=1;
display(a,b,c,d,e,f);
if(ok)//更改密码时,当所有六位新密码均被按下时,可以按下此键,结
束密码更改('
)
{//其她时间按下此键无效
ok=0;
genggai=0;
old1=new1;
old2=new2;
old3=new3;
//此时,旧的密码将被代替old4=new4;
old5=new5;
old6=new6;
//新密码写入存储区。
write24c02(110,old1);
write24c02(111,old2);
write24c02(112,old3);
write24c02(113,old4);
write24c02(114,old5);
write24c02(115,old6);
a=16;
b=16;
c=16;
d=16;
e=16;
f=16;
if(retry)//当重试按键被按下,retry会被置位
retry=0;
a=16;
new1=0;
new2=0;
new3=0;
new4=0;
new5=0;
new6=0;
if(close)//当关闭密码锁按键被按下,close会被置位
close=0;
genggai=O;
/所有变量均被清零。
wei=0;
wanbi=0;
allow=0;
P1=0xff;
new1=0;
//实时显示
voidserial_interrpt(void)interrupt4
if(RI==1)
RI=0;
input=SBUF;
on=1;
//输入数据标志位