導航:首頁 > 操作系統 > 單片機的密碼

單片機的密碼

發布時間:2023-01-20 10:03:36

⑴ 基於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('',1);

cnt--;

num=0;

}

if(num==13)

{



flag=1;

num=0;

fset=0;

setf=0;

// goto chuz;

}


}

cnt=0;

}

if(flag==1)

{

write(0x01,0);

write(0x80,0);

for(hp=0;hp<15;hp++)

{

write(fom[hp],1);

}

flag=0;

}

if(num==11)

{

write(0x80+0x40+cnt-1,0);

write('',1);

cnt--;

num=0;

}

if(num==12)

{

if(dflag==1)

setf=1;

num=0;

}

if(num==13)

{

num=0;

write(0x80+0x40+10,0);

if(wordbuf[0]==password[0]&&wordbuf[1]==password[1]&&wordbuf[2]==password[2]&&wordbuf[3]==password[3]&&wordbuf[4]==password[4]&&wordbuf[5]==password[5])

{


for(hp=0;hp<5;hp++)

{

write(state1[hp],1);

}

sflag=0;

dflag=1;

}

else

{

for(hp=0;hp<5;hp++)

{

write(state2[hp],1);

}

sflag++;


}

}

if(sflag==3)

{

alarm=!alarm;

//delay(9);

}

if(num==14)

{

num=0;

cnt=0;

write(0x01,0);

write(0x80,0);

for(hp=0;hp<15;hp++)

{

write(fom[hp],1);

}

}

if(num==15)

{

if(dflag==1)

{

open=0;

dflag=0;

}

}

}

}


void keyscan ()


{

uchar tem,temp;

P3=0xfe;

temp=P3;

tem=temp&0xf0;

if (tem!=0xf0) //沒有鍵按下時它的值是不變的,即仍為0XF0,而有鍵接下時要變

{

delay(5); //延時消抖

temp=P3;

tem=temp&0xf0;

if (tem!=0xf0) //確認有鍵按下

{

temp=P3;

tem=temp&0xf0; //這里也可以不要這一步,但下面的case里的值也要變

switch (tem)

{

case 0xe0: num=0; break;

case 0xd0: num=1; break;

case 0xb0: num=2; break;

case 0x70: num=3; break;

default : ; break ;



}

while(tem!=0xf0) //等待鬆手

{

temp=P3;

tem=temp&0xf0;


}

}


}

P3=0xfd;

temp=P3;

tem=temp&0xf0;

if (tem!=0xf0)

{

delay(5);

temp=P3;

tem=temp&0xf0;

if (tem!=0xf0)

{

temp=P3;

tem=temp&0xf0;

switch (tem)

{

case 0xe0: num=4; break;

case 0xd0: num=5; break;

case 0xb0: num=6; break;

case 0x70: num=7; break;

default : ; break ;



}

while(tem!=0xf0)

{

temp=P3;

tem=temp&0xf0;


}

}


}

P3=0xfb;

temp=P3;

tem=temp&0xf0;

if (tem!=0xf0)

{

delay(5);

temp=P3;

tem=temp&0xf0;

if (tem!=0xf0)

{

temp=P3;

tem=temp&0xf0;

switch (tem)

{

case 0xe0: num=8; break;

case 0xd0: num=9; break;

case 0xb0: num=10; break;

case 0x70: num=11; break;

default : ; break ;



}

while(tem!=0xf0)

{

temp=P3;

tem=temp&0xf0;


}

}


}

P3=0xf7;

temp=P3;

tem=temp&0xf0;

if (tem!=0xf0)

{

delay(5);

temp=P3;

tem=temp&0xf0;

if (tem!=0xf0)

{

temp=P3;

tem=temp&0xf0;

switch (tem)

{

case 0xe0: num=12; break;

case 0xd0: num=13; break;

case 0xb0: num=14; break;

case 0x70: num=15; break;

default : ; break ;



}

while(tem!=0xf0)

{

temp=P3;

tem=temp&0xf0;


}

}


}

}

⑺ 單片機密碼鎖怎麼判斷密碼正確

假設你用的是最基礎的51單片機,
首先你要知道你的密碼是不是可以修改的,如果想設計成密碼能修改的,要加上非易失存儲器,就是掉電以後也能存儲數據的,類似於24系列的存儲器。如果只是4位密碼的話,24C02完全足夠了,也可以用一個18B20,用裡面的兩個非易失高低溫存儲位元組保存,不過四位密碼你要保存成BCD格式了。這個你自己斟酌了。
如果設計成不用修改密碼的,那就在程序初始化的時候,用一個數組保存密碼,然後依次判斷輸入的密碼和你保存的密碼就行了。給你寫個大概的框框,你參考吧
不能修改密碼的程序
code
uchar
password[4]={2,3,6,8};
//保存密碼的數組
密碼
2,3,6,8,
uchar
Getinput(void);//讀取一次有效輸入的值,按照你的實際硬體自己編寫
main()
{
uchar
i;
uchar
input[4]={0,0,0,0};
for(i=0;i<4;i++)
{
input[i]=Getinput();//讀取輸入的密碼
if(input[i]!=password[i])//如果密碼輸入錯誤
{
i=0;
break;//退出循環
}
}
if(3==i)
//判斷是否4為密碼都輸入正確
{
i=0;
open();//這里是你的開鎖函數
}
}
這只是簡單的實現,你還要考慮很多細節問題,比如輸入錯誤密碼的次數,還有開鎖與關鎖的相關提示等。

閱讀全文

與單片機的密碼相關的資料

熱點內容
6s怎麼外接u盤需要什麼app 瀏覽:131
linux查看文件許可權命令 瀏覽:685
安卓手游存檔怎麼用 瀏覽:761
linuxyum安裝ftp 瀏覽:690
村委會主任可以推行政命令嗎 瀏覽:102
電腦文件夾封面多張圖片 瀏覽:263
網吧總伺服器叫什麼 瀏覽:922
多個演算法解決同一個問題 瀏覽:455
小車解壓後我的購車發票呢 瀏覽:977
做app開發用什麼雲伺服器 瀏覽:177
linux網卡子介面 瀏覽:985
21歲職高畢業學程序員怎麼學 瀏覽:321
vs如何對單個文件編譯 瀏覽:6
為什麼有的電腦不能安裝python 瀏覽:75
金蝶迷你版加密狗檢測到過期 瀏覽:186
硬體描述語言編譯結果 瀏覽:655
程序員逆天改命 瀏覽:19
金斗雲伺服器 瀏覽:447
港口工程pdf 瀏覽:770
程序設計語言pdf 瀏覽:434