ACCESS數據庫找回忘了的密碼的原理
在Access數據庫中,為了安全起見,可以為所建的數據庫設置密碼。但是,密碼忘了怎么辦?別急,這里介紹一種找回密碼的方法。
用Access所建的數據庫,在庫文件的地址00000042處開始的13個字節是Access庫的密碼位。如果一個未加密的庫,這13個字節原始數據依次為:86 FB 37 5D 44 9C FA C6 28 E6 13。事實上,當你設置了密碼后,Access就將你的密碼(請注意你所輸入的密碼是本文字符)的ACSII碼與以上的13個字節數據進行異或操作,因此,從庫文件的地址00000042開始的13個字節就變成了密鑰了。例如,如果你設置的密碼為abc,經過異或操作后,則從00000042處開始的13個字節的數據變成了E7 99 8F 37 5D 44 9C FA C6 28 E6 13。一個數據經過一次異或操作后,再一次經過同樣的異或操作就可還原了。因此,對已經設置了密碼的Access庫,只要將13個密鑰數據與原始的13個數據進行一次異或操作就可得到密碼了。
以下是一個C語言的破解程序:
/*假設加密后的Access庫為myacc.mdb,并存放在C盤的根目錄下*/
#include ″stdio.h″
main()
{FILE * fp
char mm0[13]={0x86,0xfb,0xec,0x37,0x5d,0x44,0x9c,0xfa,0xc6,0x5e,0x28,0xe6,0x13};
/*這是13個原始數據*/
char mml[13],mm2[13];
/*mm1用來存放加密后的13個密鑰;mm2用來存放密碼*/
int i,k;
fp=fopen(″c:\myacc.mdb″,″rb″);
if(fp=NULL){
printf(″ 不能打開該庫!″);
exit(0);}
rewind(fp);fseek(fp,0x42L,0);
fread(mm1,13,1,fp);/*讀取密鑰*/
for(i=0;i<13;i++){
mm2[i]=mm0[i]^mm[i];*/原始數據與密鑰異或*/
else
break;}
k=1;fclose(fp);
if(k=0)
printf(″未設密碼!″);
else{printf(″ 密碼是: ″);
for(i=0;ibr> printf(″%c,mm2[i]″);}}
順便提一句,Access庫設置密碼時,雖然允許輸入最多14個密碼字符,但只有前13個有效。
主站蜘蛛池模板:
久青草国产手机在线观
|
亚洲精品久久片久久
|
久久精品国产精品亚洲
|
在线日韩中文字幕
|
免费观看成人www精品视频在线
|
毛片网站在线看
|
国产普通话一二三道
|
男人女人做刺激视频免费
|
国产成人区
|
日韩乱淫|
国产一级在线现免费观看
|
亚洲精品视频在线观看免费
|
成人欧美一区二区三区视频
|
中国一级毛片免费观看
|
久久久久久久久一次
|
一级片在线免费看
|
欧美精品一区二区在线观看播放
|
日韩中文字幕在线观看
|
欧美成人免费tv在线播放
|
精品国产免费观看一区
|
久久国产精品久久精品国产
|
亚洲精品日本
|
成人欧美在线
|
7777在线视频
|
亚洲黄色免费观看
|
日韩中文字幕视频在线
|
亚洲欧美日韩国产
|
a毛片成人免费全部播放
|
国产精品久久久久久吹潮
|
91av综合|
久久在线观看免费视频
|
99久久久国产精品免费播放器
|
97一级毛片全部免费播放
|
最近中文在线中文
|
亚洲欧美综合久久
|
免费视频久久
|
国产成人微拍精品
|
正在播放的国产a一片
|
一级做a爱 一区
|
美国一级特a黄
|
久久久一区二区三区不卡
|