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個有效。
      北大青鳥網上報名
      北大青鳥招生簡章
      主站蜘蛛池模板: 亚洲综合色一区二区三区| 日本在线视频一区| 日韩一区二区a片免费观看| 日本精品一区二区三区在线视频一| 精品乱子伦一区二区三区高清免费播放| 在线视频一区二区| 国产成人精品无码一区二区三区 | 国产SUV精品一区二区88L| 无码人妻精品一区二区三区夜夜嗨| 精品一区二区三区电影| 中文字幕日韩欧美一区二区三区| 91精品国产一区| 精品一区二区三区波多野结衣| 99久久精品国产高清一区二区 | 亚洲天堂一区二区| 日本道免费精品一区二区| 一区二区三区免费视频网站| 国产一区二区影院| 国产一区在线观看免费| 日韩一区二区三区电影在线观看 | 亚洲国产av一区二区三区| 日韩精品福利视频一区二区三区| 一区二区三区高清| 国产欧美一区二区精品仙草咪| 伊人色综合一区二区三区影院视频| 97久久精品一区二区三区| 国产电影一区二区| 亚洲AV无码一区二区乱子仑| 蜜臀AV无码一区二区三区 | 国产精品无码一区二区三区电影| 香蕉视频一区二区三区| 日韩人妻无码一区二区三区综合部| 国产精品自在拍一区二区不卡| 精品国产日韩亚洲一区| 日本不卡在线一区二区三区视频 | 国产伦精品一区二区三区不卡| 国产福利无码一区在线| 麻豆一区二区三区蜜桃免费| 久久国产香蕉一区精品| 日韩人妻无码一区二区三区久久| 日韩一区二区在线视频|