⑴ 基于51单片机的密码锁
基于51单片机的密码锁的话其实我是不知道是什么意思的 所以说不好意思咯(๑ó﹏ò๑)
⑵ 单片机电子密码锁设置
我发了
⑶ 51单片机C语言简易的密码输入
这样子当然是不行的,首先按键没有消抖,再者代码根本就不对。I大于4我没看懂是干嘛的,像这样子子基本就是只要在I>4的时候按下P1_7,就解锁成功了。密码锁形同虚设。
这样子改看看,不行再追问,我这边没得编译运行。:
下面的代码没有消抖,如需要楼主自己加吧。
uchartmp;
for(i=0;i<6;i++)
{
while((tmp=P1)!=0);//如果按键按下是0的话就不用改,如果按键按下是1的话改成0XFF。这句是先检测是否有按键按下。
if(P1==tab[i])continue;
else
{
i=0;
continue;
}
if(P1_7==0&&i=5)
ledg=~ledg,ledr=~ledr;
else...
}
⑷ 基于单片机的电子密码锁设计
功能键
S6---S15 数字键0-9
S16---更改密码 S17---更改密码完毕后确认
S18---重试密码、重新设定 S19---关闭密码锁
初始密码:000000 密码位数:6位
注意:掉电后,所设密码会丢失,重新上点时,密码恢复为原始的000000
与P1相连的8位发光LED点亮代表锁被打开;熄灭代表锁被锁上
程序功能: 本程序结合了24C02存储器的存储功能,可以掉电保存密码。
第一次运行时,若输入000000原始密码后无反应,可以试验着将主程序中前面的
一小段被注释线屏蔽的程序前的注释线删掉,然后重新编译下载(可以将密码还原为000000)。
此后,再将这小段程序屏蔽掉,再编译下载。方可正常使用。
1、开锁:
下载程序后,直接按六次S7(即代表数字1),8位LED亮,锁被打开,输入密码时,
六位数码管依次显示小横杠。
2、更改密码:
只有当开锁(LED亮)后,该功能方可使用。
首先按下更改密码键S16,然后设置相应密码,此时六位数码管会显示设置密码对应
的数字。最后设置完六位后,按下S17确认密码更改,此后新密码即生效。
3、重试密码:
当输入密码时,密码输错后按下键S18,可重新输入六位密码。
当设置密码时,设置中途想更改密码,也可按下此键重新设置。
4、关闭密码锁:
按下S19即可将打开的密码锁关闭。
推荐初级演示步骤:输入原始密码000000---按下更改密码按键S16---按0到9设置密码---按S17
确认密码更改---按S18关闭密码锁---输入新的密码打开密码锁
*******************************************************************************/
#include<reg52.h>
#include <intrins.h>
#define uint unsigned int
#define uchar unsigned char
uchar old1,old2,old3,old4,old5,old6; //原始密码000000
uchar new1,new2,new3,new4,new5,new6; //每次MCU采集到的密码输入
uchar a=16,b=16,c=16,d=16,e=16,f=16; //送入数码管显示的变量
uchar wei,key,temp;
bit allow,genggai,ok,wanbi,retry,close; //各个状态位
sbit la=P2^6;
sbit wela=P2^7;
sbit beep=P2^3;
sbit sda=P2^0; //IO口定义
sbit scl=P2^1;
unsigned char code table[]=
{0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,
0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00,0x40};
/*****************IIC芯片24C02存储器驱动程序************************************/
void nop()
{
_nop_();
_nop_();
}
/////////24C02读写驱动程序////////////////////
void delay1(unsigned int m)
{ unsigned int n;
for(n=0;n<m;n++);
}
void init() //24c02初始化子程序
{
scl=1;
nop();
sda=1;
nop();
}
void start() //启动I2C总线
{
sda=1;
nop();
scl=1;
nop();
sda=0;
nop();
scl=0;
nop();
}
void stop() //停止I2C总线
{
sda=0;
nop();
scl=1;
nop();
sda=1;
nop();
}
void writebyte(unsigned char j) //写一个字节
{
unsigned char i,temp;
temp=j;
for (i=0;i<8;i++)
{
temp=temp<<1;
scl=0;
nop();
sda=CY; //temp左移时,移出的值放入了CY中
nop();
scl=1; //待sda线上的数据稳定后,将scl拉高
nop();
}
scl=0;
nop();
sda=1;
nop();
}
unsigned char readbyte() //读一个字节
{
unsigned char i,j,k=0;
scl=0; nop(); sda=1;
for (i=0;i<8;i++)
{
nop(); scl=1; nop();
if(sda==1)
j=1;
else
j=0;
k=(k<<1)|j;
scl=0;
}
nop();
return(k);
}
void clock() //I2C总线时钟
{
unsigned char i=0;
scl=1;
nop();
while((sda==1)&&(i<255))
i++;
scl=0;
nop();
}
////////从24c02的地址address中读取一个字节数据/////
unsigned char read24c02(unsigned char address)
{
unsigned char i;
start();
writebyte(0xa0);
clock();
writebyte(address);
clock();
start();
writebyte(0xa1);
clock();
i=readbyte();
stop();
delay1(100);
return(i);
}
//////向24c02的address地址中写入一字节数据info/////
void write24c02(unsigned char address,unsigned char info)
{
start();
writebyte(0xa0);
clock();
writebyte(address);
clock();
writebyte(info);
clock();
stop();
delay1(5000); //这个延时一定要足够长,否则会出错。因为24c02在从sda上取得数据后,还需要一定时间的烧录过程。
}
/****************************密码锁程序模块********************************************************/
void delay(unsigned char i)
{
uchar j,k;
for(j=i;j>0;j--)
for(k=125;k>0;k--);
}
void display(uchar a,uchar b,uchar c,uchar d,uchar e,uchar f)
{
la=0;
P0=table[a];
la=1;
la=0;
wela=0;
P0=0xfe;
wela=1;
wela=0;
delay(5);
P0=table[b];
la=1;
la=0;
P0=0xfd;
wela=1;
wela=0;
delay(5);
P0=table[c];
la=1;
la=0;
P0=0xfb;
wela=1;
wela=0;
delay(5);
P0=table[d];
la=1;
la=0;
P0=0xf7;
wela=1;
wela=0;
delay(5);
P0=table[e];
la=1;
la=0;
P0=0xef;
wela=1;
wela=0;
delay(5);
P0=table[f];
la=1;
la=0;
P0=0xdf;
wela=1;
wela=0;
delay(5);
}
void keyscan()
{
{
P3=0xfe;
temp=P3;
temp=temp&0xf0;
if(temp!=0xf0)
{
delay(10);
if(temp!=0xf0)
{
temp=P3;
switch(temp)
{
case 0xee:
key=0;
wei++;
break;
case 0xde:
key=1;
wei++;
break;
case 0xbe:
key=2;
wei++;
break;
case 0x7e:
key=3;
wei++;
break;
}
while(temp!=0xf0)
{
temp=P3;
temp=temp&0xf0;
beep=0;
}
beep=1;
}
}
P3=0xfd;
temp=P3;
temp=temp&0xf0;
if(temp!=0xf0)
{
delay(10);
if(temp!=0xf0)
{
temp=P3;
switch(temp)
{
case 0xed:
key=4;
wei++;
break;
case 0xdd:
key=5;
wei++;
break;
case 0xbd:
key=6;
wei++;
break;
case 0x7d:
key=7;
wei++;
break;
}
while(temp!=0xf0)
{
temp=P3;
temp=temp&0xf0;
beep=0;
}
beep=1;
}
}
P3=0xfb;
temp=P3;
temp=temp&0xf0;
if(temp!=0xf0)
{
delay(10);
if(temp!=0xf0)
{
temp=P3;
switch(temp)
{
case 0xeb:
key=8;
wei++;
break;
case 0xdb:
key=9;
wei++;
break;
case 0xbb:
genggai=1;
wei=0;
break;
case 0x7b:
if(allow)
ok=1;
break;
}
while(temp!=0xf0)
{
temp=P3;
temp=temp&0xf0;
beep=0;
}
beep=1;
}
}
P3=0xf7;
temp=P3;
temp=temp&0xf0;
if(temp!=0xf0)
{
delay(10);
if(temp!=0xf0)
{
temp=P3;
switch(temp)
{
case 0xe7:
retry=1;
break;
case 0xd7:
close=1;
break;
}
while(temp!=0xf0)
{
temp=P3;
temp=temp&0xf0;
beep=0;
}
beep=1;
}
}
}
}
void shumima() //对按键采集来的数据进行分配
{
if(!wanbi)
{
switch(wei)
{
case 1:new1=key;
if(!allow) a=17;
else a=key; break;
case 2:new2=key;
if(a==17) b=17;
else b=key; break;
case 3:new3=key;
if(a==17) c=17;
else c=key; break;
case 4:new4=key;
if(a==17) d=17;
else d=key; break;
case 5:new5=key;
if(a==17) e=17;
else e=key; break;
case 6:new6=key;
if(a==17) f=17;
else f=key;
wanbi=1; break;
}
}
}
void yanzheng() //验证密码是否正确
{
if(wanbi) //只有当六位密码均输入完毕后方进行验证
{
if((new1==old1)&(new2==old2)&(new3==old3)&(new4==old4)&(new5==old5)&(new6==old6))
allow=1; //当输入的密码正确,会得到allowe置一
}
}
void main()
{
init(); //初始化24C02
/*********下面的一小段程序的功能为格式化密码存储区。************
******当24c02中这些存储区由于其他程序的运行而导致***************
*******所存数据发生了变化,或者密码遗忘时, ********************
******可以删掉其前面的注释线,然后重新编译下载。****************
******而将密码还原为000000后,请将下面的程序用******************
******注释屏蔽掉,重新编译、下载,方可正常使用****************/
// write24c02(110,0x00);
// write24c02(111,0x00);//24c02的第110到115地址单元作为密码存储区
// write24c02(112,0x00);
// write24c02(113,0x00);
// write24c02(114,0x00);
// write24c02(115,0x00);
/*******************************************************************/
old1=read24c02(110);
old2=read24c02(111);
old3=read24c02(112);
old4=read24c02(113);
old5=read24c02(114);
old6=read24c02(115);
while(1)
{
keyscan();
shumima();
yanzheng();
if(allow) //验证完后,若allow为1,则开锁
{
P1=0x00;
if(!genggai)
wanbi=0;
}
if(genggai) //当S16更改密码键被按下,genggai会被置一
{
if(allow) //若已经把锁打开,才有更改密码的权限
{
while(!wanbi) //当新的六位密码没有设定完,则一直在这里循环
{
keyscan();
shumima();
if(retry|close) //而当探测到重试键S18或者关闭密码锁键S19被按下时,则跳出
{ wanbi=1;
break;
}
display(a,b,c,d,e,f);
}
}
}
if(ok) //更改密码时,当所有六位新密码均被按下时,可以按下此键,结束密码更改
{ //其他时间按下此键无效
ok=0; wei=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) //当重试按键S18被按下,retry会被置位
{
retry=0; wei=0;wanbi=0;
a=16;b=16;c=16;d=16;e=16;f=16;
new1=0;new2=0;new3=0;new4=0;new5=0;new6=0;
}
if(close) //当关闭密码锁按键被按下,close会被置位
{
close=0;genggai=0;//所有变量均被清零。
wei=0; wanbi=0;
allow=0;
P1=0xff;
a=16;b=16;c=16;d=16;e=16;f=16;
new1=0;new2=0;new3=0;new4=0;new5=0;new6=0;
}
display(a,b,c,d,e,f); //实时显示
}
}
对着代码自己做吧,,要是还做不出来,,那我就不说什么了,,
⑸ VB显示单片机输入的密码(电子密码锁设计)
1。
根据实验任务来设置一个好的密码,采用二个按键实现输入功能,输入正确的密码,当密码,锁就打开,如果输入了不正确的密码三次,锁按钮3秒钟,同时发现报警声,没有任何按键按下,直到三种后,只要打开按键锁定功能;否则仍按钮三秒钟内按下时,它重新锁定按键3秒和报警。
2。原理
图4.32.1
3。系统硬件电路板连接
(1)。在“单片机系统”区域P0.0/AD0线连接到“音频放大模块”区域中的SPK IN端子;
(2)。 “音频放大模块”区域中的SPK OUT端子的扬声器和;
(3)。在“单片机系统”区域P2.0/A8-P2.7/A15与连接到任何一个ABCDEFGH终端“四个静态数码显示”区域8芯电缆;
(4)。在“单片机系统”区域中的P1.0用导线连接到“八发光二极管模块”区域中的L1端子;
(5)。在“单片机系统”区域P3.6/WR,P3.7/RD连接到SP1和SP2终端的“独立式键盘”区域中的线??;
4。节目内容
(1)。设置一个密码,这个程序中的密码是固定在程序存储器ROM,假设默认密码是五个密码“12345”。
(2)。输入密码问题:感谢,那么关键之一,功能键,数字键的另一个关键。在输入过程中,先输入密码的长度,再根据密码的位数输入密码,该密码,直到所有的长度已输入;功能键或输入后确认即可完成密码的输入过程。入比较处理,以确定密码的状态和相应的过程。
(3)。键禁止功能:初始化,允许当按钮被按下时,开始进入键来标识状态的键输入密码,按键锁定功能被激活,但一个国家的开始发生在一个不正确的密码输入了三个倍的情况下。
5 C语言源代码
#包括
无符号的字符代码PS [] = {1,2,3,4,5};
无符号的字符代码dispcode [] = {的0x3F,0X06,为0x5B,0X4F,0x66,
0x6d,0x7d,0X07,到0x7f,0x6f,为0x00,0X40};
无符号字符pslen = 9;
无符号字符templen;
无符号字符型位数;
无符号字符funcount;
无符号字符digitcount;
unsigned char型psbuf [9];
位cmpflag;
位hibitflag;
位读ErrorFlag;
位rightflag;
无符号整型秒3;
无符号整型AA;
无符号整型BB;
位alarmflag;
位exchangeflag;
无符号整型立方厘米;
无符号整型日;
位okflag;
无符号字符冈;
无符号字符OKB;
无效的主要(无效)
{
unsigned char型I,J;
P2 = dispcode [digitcount];
TMOD = 0X01;
TH0 =(65536-500)/ 256;
TL0 =(65536-500)%256;
TR0 = 1;
ET0 = 1;
EA = 1;
而(1)
{
如果(cmpflag == 0)
{
如果(P3_6 == 0)/ /功能键 {
就(i = 10,I> 0,I - )
为(J = 248; J> 0;的J - );
如果(P3_6 == 0)
{
如果(hibitflag == 0)/ /如果按键被锁定
funcount + +; (funcount == pslen +2)/ /前
如果有按功能键1,然后按数字键1,完成密码长度的输入
{
funcount = 0;
cmpflag = 1;
P1 = dispcode [funcount]; / /你可以决定是否按下灯按钮,
}
{
秒3 = 0;
同时(P3_6 == 0);
如果(P3_7 == 0)/ /数字键
{
就(i = 10;> 0;我 - )
为(J = 248; J> 0;的J - );
如果(P3_7 == 0)
{
如果(hibitflag == 0)
{
digitcount + +;
如果(digitcount == 10)
{
digitcount = 0;
P2 = dispcode [digitcount];
如果(funcount == 1)/ /按功能键,键入密码长度
{
pslen = digitcount;
templen = pslen;
否则,如果(funcount> 1)/ /开始记录你的密码
{
psbuf [funcount-2] = digitcount;
{
秒3 = 0;
同时(P3_7 == 0);
} / /原这个“}”
其他/ /比较
{
cmpflag = 0;
就(i = 0;我<pslen,我+ +)
{
如果(!PS [I] = psbuf [I])
{
hibitflag = 1; / /密码输入不正确,按键锁定功能被激活
I = pslen;
读ErrorFlag = 1;
rightflag = 0;
cmpflag = 0;
秒3 = 0;
转到一个;
CC = 0;
读ErrorFlag = 0;
rightflag = 1;
hibitflag = 0;
一:cmpflag = 0;
}
T0无效(无效)中断1使用0
=(65536-500)/ 256 ;
TL0 =(65536-500)%256;
如果((读ErrorFlag == 1)&&(rightflag == 0))
{
BB +;
如果(BB == 800)
{
BB = 0;
alarmflag =alarmflag;
}
如果(alarmflag == 1)
{
P0_0 =P0_0; / /报警声
}
AA +;
如果(AA == 800)
{
AA = 0;
P0_1 =P0_1; / / LED2发光二极管闪光灯
}
秒3 +;
如果(秒3 == 6400)/ /闪四次(8转换),自动复位到以前的按ENTER键状态
{
秒3 = 0;
hibitflag = 0;
读ErrorFlag = 0;
rightflag = 0;
cmpflag = 0;
P0_1 = 1;
alarmflag = 0;
BB = 0;
AA = 0;
如果((读ErrorFlag == 0)&&(rightflag == 1))/ /发出“叮咚”声
{ BR /> P0_1 = 0; / / LED2 LED灯
CC + +;
如果(CC <1000)
{
okflag = 1;
否则,如果(CC <2000)
{
okflag = 0;
其他/ /自动复位到国家新闻
{
读ErrorFlag = 0之前ENTER;
rightflag = 0;
hibitflag = 0;
cmpflag = 0;
P0_1 = 1; / / LED2发光二极管消除
CC = 0;
冈= 0;
OKB = 0;
okflag = 0;
P0_0 = 1;
}
如果(okflag == 1)
{
冈+ +;
如果(OKA == 2)
{
丘= 0;
P0_0 =P0_0;
{
OKB + +;
如果(OKB == 3)
{
OKB = 0;
P0_0 =P0_0;
⑹ 51单片机的电子密码锁程序,用KEIL C写的
以前帮别人做过一个类似的
#include<reg52.h>
#include <def.h>
#include"lcd.c"
uchar key;
uchar num;
sbit alarm=P2^4;
sbit open=P2^1;
uchar code table[]={' ','1','2','3',
'4','5','6','7',
'8','9','0'};
void keyscan();
uchar hptable[10];
uchar password[6];
uchar wordbuf[6];
uchar fom[]="input password:";
uchar change[]="set mask:";
uchar state1[]="right";
uchar state2[]="error";
uchar sflag;
uchar dflag,cnt;
uchar setf,fset;
uchar flag;
void main ()
{
uchar hp;
alarm=0;
flag=0;
setf=0;
fset=0;
dflag=0;
lcden=0;
lcdrw=1;
lcdrs=1;
P3=0x0f;
for(hp=0;hp<6;hp++)
{
password[hp]='8';
}
write(0x38,0); //0为写命令
delay(9);
write(0x08,0);
write(0x01,0);
write(0x06,0);
write(0x0c,0);
write(0x80,0);
for(hp=0;hp<15;hp++)
{
write(fom[hp],1);
}
while(1)
{
// alarm=!alarm;
keyscan();
if(setf==0)
{
if(num>=1&&num<=10)
{
write(0x80+0x40+cnt,0);
write('*',1);
wordbuf[cnt]=table[num];
cnt++;
num=0;
}
}
else
{
write(0x01,0);
write(0x80,0);
for(hp=0;hp<9;hp++)
{
write(change[hp],1);
}
fset=1;
cnt=0;
while(fset)
{
keyscan();
if(num>=1&&num<=10)
{
write(0x80+0x40+cnt,0);
write('*',1);
password[cnt]=table[num];
cnt++;
num=0;
}
if(num==11)
{
write(0x80+0x40+cnt-1,0);
write('