![DES加密算法的實(shí)現(xiàn)(詳細(xì)版)_第1頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-9/29/7ebf3ebe-685e-46d3-b8f9-f8a56d3a6104/7ebf3ebe-685e-46d3-b8f9-f8a56d3a61041.gif)
![DES加密算法的實(shí)現(xiàn)(詳細(xì)版)_第2頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-9/29/7ebf3ebe-685e-46d3-b8f9-f8a56d3a6104/7ebf3ebe-685e-46d3-b8f9-f8a56d3a61042.gif)
![DES加密算法的實(shí)現(xiàn)(詳細(xì)版)_第3頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-9/29/7ebf3ebe-685e-46d3-b8f9-f8a56d3a6104/7ebf3ebe-685e-46d3-b8f9-f8a56d3a61043.gif)
![DES加密算法的實(shí)現(xiàn)(詳細(xì)版)_第4頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-9/29/7ebf3ebe-685e-46d3-b8f9-f8a56d3a6104/7ebf3ebe-685e-46d3-b8f9-f8a56d3a61044.gif)
![DES加密算法的實(shí)現(xiàn)(詳細(xì)版)_第5頁(yè)](http://file1.renrendoc.com/fileroot_temp2/2020-9/29/7ebf3ebe-685e-46d3-b8f9-f8a56d3a6104/7ebf3ebe-685e-46d3-b8f9-f8a56d3a61045.gif)
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、v 3DES加密算法的實(shí)現(xiàn)畢業(yè)論文 一、DES加密及解密算法程序源代碼:#include using namespace std;const static char IP_Table = /IP_Table置換 58, 50, 42, 34, 26, 18, 10, 2, 60, 52, 44, 36, 28, 20, 12, 4, 62, 54, 46, 38, 30, 22, 14, 6, 64, 56, 48, 40, 32, 24, 16, 8, 57, 49, 41, 33, 25, 17, 9, 1, 59, 51, 43, 35, 27, 19, 11, 3, 61, 53, 4
2、5, 37, 29, 21, 13, 5, 63, 55, 47, 39, 31, 23, 15, 7; const static char Final_Table = /最終置換 40, 8, 48, 16, 56, 24, 64, 32, 39, 7, 47, 15, 55, 23, 63, 31, 38, 6, 46, 14, 54, 22, 62, 30, 37, 5, 45, 13, 53, 21, 61, 29, 36, 4, 44, 12, 52, 20, 60, 28, 35, 3, 43, 11, 51, 19, 59, 27, 34, 2, 42, 10, 50, 18,
3、58, 26, 33, 1, 41, 9, 49, 17, 57, 25;const static char S_Box864 = /s_box /* S1 */ 14, 4, 13, 1, 2, 15, 11, 8, 3, 10, 6, 12, 5, 9, 0, 7,0, 15, 7, 4, 14, 2, 13, 1, 10, 6, 12, 11, 9, 5, 3, 8,4, 1, 14, 8, 13, 6, 2, 11, 15, 12, 9, 7, 3, 10, 5, 0, 15, 12, 8, 2, 4, 9, 1, 7, 5, 11, 3, 14, 10, 0, 6, 13, /* S
4、2 */ 15, 1, 8, 14, 6, 11, 3, 4, 9, 7, 2, 13, 12, 0, 5, 10,3, 13, 4, 7, 15, 2, 8, 14, 12, 0, 1, 10, 6, 9, 11, 5,0, 14, 7, 11, 10, 4, 13, 1, 5, 8, 12, 6, 9, 3, 2, 15, 13, 8, 10, 1, 3, 15, 4, 2, 11, 6, 7, 12, 0, 5, 14, 9, /* S3 */ 10, 0, 9, 14, 6, 3, 15, 5, 1, 13, 12, 7, 11, 4, 2, 8, 13, 7, 0, 9, 3, 4,
5、 6, 10, 2, 8, 5, 14, 12, 11, 15, 1, 13, 6, 4, 9, 8, 15, 3, 0, 11, 1, 2, 12, 5, 10, 14, 7,1, 10, 13, 0, 6, 9, 8, 7, 4, 15, 14, 3, 11, 5, 2, 12, /* S4 */7, 13, 14, 3, 0, 6, 9, 10, 1, 2, 8, 5, 11, 12, 4, 15, 13, 8, 11, 5, 6, 15, 0, 3, 4, 7, 2, 12, 1, 10, 14, 9, 10, 6, 9, 0, 12, 11, 7, 13, 15, 1, 3, 14,
6、 5, 2, 8, 4,3, 15, 0, 6, 10, 1, 13, 8, 9, 4, 5, 11, 12, 7, 2, 14, /* S5 */2, 12, 4, 1, 7, 10, 11, 6, 8, 5, 3, 15, 13, 0, 14, 9, 14, 11, 2, 12, 4, 7, 13, 1, 5, 0, 15, 10, 3, 9, 8, 6,4, 2, 1, 11, 10, 13, 7, 8, 15, 9, 12, 5, 6, 3, 0, 14, 11, 8, 12, 7, 1, 14, 2, 13, 6, 15, 0, 9, 10, 4, 5, 3, /* S6 */ 12
7、, 1, 10, 15, 9, 2, 6, 8, 0, 13, 3, 4, 14, 7, 5, 11, 10, 15, 4, 2, 7, 12, 9, 5, 6, 1, 13, 14, 0, 11, 3, 8,9, 14, 15, 5, 2, 8, 12, 3, 7, 0, 4, 10, 1, 13, 11, 6,4, 3, 2, 12, 9, 5, 15, 10, 11, 14, 1, 7, 6, 0, 8, 13, /* S7 */4, 11, 2, 14, 15, 0, 8, 13, 3, 12, 9, 7, 5, 10, 6, 1, 13, 0, 11, 7, 4, 9, 1, 10,
8、 14, 3, 5, 12, 2, 15, 8, 6,1, 4, 11, 13, 12, 3, 7, 14, 10, 15, 6, 8, 0, 5, 9, 2,6, 11, 13, 8, 1, 4, 10, 7, 9, 5, 0, 15, 14, 2, 3, 12, /* S8 */ 13, 2, 8, 4, 6, 15, 11, 1, 10, 9, 3, 14, 5, 0, 12, 7,1, 15, 13, 8, 10, 3, 7, 4, 12, 5, 6, 11, 0, 14, 9, 2,7, 11, 4, 1, 9, 12, 14, 2, 0, 6, 10, 13, 15, 3, 5,
9、8,2, 1, 14, 7, 4, 10, 8, 13, 15, 12, 9, 0, 3, 5, 6, 11;const static char Rar_Table = /壓縮置換 14, 17, 11, 24, 1, 5,3, 28, 15, 6, 21, 10, 23, 19, 12, 4, 26, 8, 16, 7, 27, 20, 13, 2, 41, 52, 31, 37, 47, 55, 30, 40, 51, 45, 33, 48, 44, 49, 39, 56, 34, 53, 46, 42, 50, 36, 29, 32;const static char Exp_Table
10、 = /擴(kuò)展置換 32, 1, 2, 3, 4, 5,4, 5, 6, 7, 8, 9,8, 9, 10, 11, 12, 13, 12, 13, 14, 15, 16, 17, 16, 17, 18, 19, 20, 21, 20, 21, 22, 23, 24, 25, 24, 25, 26, 27, 28, 29, 28, 29, 30, 31, 32, 1;const static char P_Table=/P置換 16, 7, 20, 21, 29, 12, 28, 17,1, 15, 23, 26,5, 18, 31, 10,2, 8, 24, 14, 32, 27, 3, 9,
11、 19, 13, 30, 6, 22, 11, 4, 25;const static char KeyRar_Table= 57, 49, 41, 33, 25, 17, 9,1, 58, 50, 42, 34, 26, 18, 10, 2, 59, 51, 43, 35, 27, 19, 11, 3, 60, 52, 44, 36, 63, 55, 47, 39, 31, 23, 15,7, 62, 54, 46, 38, 30, 22, 14, 6, 61, 53, 45, 37, 29, 21, 13, 5, 28, 20, 12, 4;/設(shè)置全局變量,16輪密鑰bool key1648
12、=0;void ByteToBit(bool *Out,char *In,int bits)/字節(jié)到位轉(zhuǎn)換函數(shù)int i;for(i=0;i(i%8)&1;void BitToByte(char *Out,bool *In,int bits)/位到字節(jié)轉(zhuǎn)換函數(shù)int i;for(i=0;ibits/8;i+)Outi=0;for(i=0;ibits;i+)Outi/8|=Ini(i%8);void Xor(bool *InA,const bool *InB,int length) /按位異或for(int i=0;ilength;i+)InAi=InBi;void keyfc(char *In
13、) /密鑰生成函數(shù)int i,j=0,mov,k,m;bool* key0 = new bool56;bool* keyin = new bool64;bool temp;ByteToBit(keyin,In,64); /字節(jié)到位的轉(zhuǎn)換for(i=0;i56;i+) /密鑰壓縮為56位key0i=keyinKeyRar_Tablei-1;for(i=0;i16;i+) /16輪密鑰產(chǎn)生if(i=0|i=1|i=8|i=15)mov=1;elsemov=2;for(k=0;kmov;k+) /分左右兩塊循環(huán)左移for(m=0;m8;m+)temp=key0m*7;for(j=m*7;jm*7+7
14、;j+)key0j=key0j+1;key0m*7+6=temp;temp=key00;for(m=0;m27;m+)key0m=key0m+1;key027=temp;temp=key028;for(m=28;m55;m+)key0m=key0m+1;key055=temp;for(j=0;j48;j+) /壓縮置換并儲(chǔ)存 keyij=key0Rar_Tablej-1;delete key0;delete keyin;void DES(char Out8,char In8,bool Type)/加密核心程序,Type=0時(shí)加密,反之解密bool* MW = new bool64;bool*
15、tmp = new bool32;bool* PMW = new bool64;bool* kzmw = new bool48;bool* keytem = new bool48;bool* ss = new bool32;int hang,lie,i;ByteToBit(PMW,In,64);for(int j=0;j64;j+)MWj=PMWIP_Tablej-1; /初始置換bool *Li=&MW0,*Ri=&MW32;for(i=0;i48;i+)/右明文擴(kuò)展置換kzmwi=RiExp_Tablei-1;if(Type=0)/DES加密過(guò)程for(int lun=0;lun16;lu
16、n+)for(i=0;i32;i+)ssi=Rii;for(i=0;i48;i+)/右明文擴(kuò)展置換kzmwi=RiExp_Tablei-1;for(i=0;i48;i+)keytemi=keyluni;Xor(kzmw,keytem,48);/*S盒置換*/for(i=0;i8;i+)hang=kzmwi*6*2+kzmwi*6+5;lie =kzmwi*6+1*8+kzmwi*6+2*4+kzmwi*6+3*2+kzmwi*6+4;tmpi*4+3=S_Boxi(hang+1)*16+lie%2;tmpi*4+2=(S_Boxi(hang+1)*16+lie/2)%2;tmpi*4+1=(S
17、_Boxi(hang+1)*16+lie/4)%2;tmpi*4=(S_Boxi(hang+1)*16+lie/8)%2;for(i=0;i32;i+)/P置換Rii=tmpP_Tablei-1;Xor(Ri,Li,32);/異或for(i=0;i32;i+)/交換左右明文Lii=ssi;for(i=0;i32;i+)tmpi=Lii;Lii=Rii;Rii=tmpi;for(i=0;i=0;lun-)for(i=0;i32;i+)ssi=Rii;for(i=0;i48;i+)/右明文擴(kuò)展置換kzmwi=RiExp_Tablei-1;for(i=0;i48;i+)keytemi=keyluni
18、;Xor(kzmw,keytem,48);/*S盒置換*/for(i=0;i8;i+)hang=kzmwi*6*2+kzmwi*6+5;lie =kzmwi*6+1*8+kzmwi*6+2*4+kzmwi*6+3*2+kzmwi*6+4;tmpi*4+3=S_Boxi(hang+1)*16+lie%2;tmpi*4+2=(S_Boxi(hang+1)*16+lie/2)%2;tmpi*4+1=(S_Boxi(hang+1)*16+lie/4)%2;tmpi*4=(S_Boxi(hang+1)*16+lie/8)%2;for(i=0;i32;i+)/P置換Rii=tmpP_Tablei-1;Xo
19、r(Ri,Li,32);/異或for(i=0;i32;i+)/交換左右明文Lii=ssi;for(i=0;i32;i+)tmpi=Lii;Lii=Rii;Rii=tmpi;for(i=0;i64;i+)PMWi=MWFinal_Tablei-1;BitToByte(Out,PMW,64);/位到字節(jié)的轉(zhuǎn)換delete MW;delete tmp;delete PMW;delete kzmw;delete keytem;delete ss;bool RunDes(char *Out, char *In, int datalength, char *Key, bool Type) /加密運(yùn)行函數(shù),判斷輸入以及對(duì)輸入文本8字節(jié)分割 if( !( Out & In & Key & (datalength=(datalength+7)&0xfffffff8) ) ) return fal
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 學(xué)生交流會(huì)策劃方案(8篇)
- 2025年材料用過(guò)濾袋合同采購(gòu)流程
- 2025年醫(yī)用耗材集中采購(gòu)協(xié)議
- 2025年文物遺址保護(hù)服務(wù)項(xiàng)目規(guī)劃申請(qǐng)報(bào)告
- 2025年舞蹈學(xué)校教職員工勞動(dòng)合同
- 2025年貴金屬靶材項(xiàng)目申請(qǐng)報(bào)告模板
- 2025年企業(yè)互助共享協(xié)議
- 2025年單位二手商業(yè)房產(chǎn)出售合同范本
- 2025年公司員工競(jìng)業(yè)限制協(xié)議范例
- 2025年組合開關(guān)項(xiàng)目提案報(bào)告
- 全介質(zhì)自承式架空光纜(ADSS)-設(shè)計(jì)和制造專題研討教學(xué)課件
- 義工財(cái)務(wù)管理制度范文
- 西安旅游景點(diǎn)介紹PPT模板(推薦)
- 公司實(shí)際經(jīng)營(yíng)地與公司注冊(cè)地不一致的說(shuō)明
- 電氣控制線路的設(shè)計(jì)和元器件選擇
- 貴州省工傷待遇申請(qǐng)表(綜合柜員)
- 《發(fā)展?jié)h語(yǔ)(第二版)中級(jí)綜合(Ⅰ)》第8課+課件
- GB/T 18268.1-2010測(cè)量、控制和實(shí)驗(yàn)室用的電設(shè)備電磁兼容性要求第1部分:通用要求
- GB 5009.228-2016食品安全國(guó)家標(biāo)準(zhǔn)食品中揮發(fā)性鹽基氮的測(cè)定
- 多維完美主義量表(HMPS)
- 人教版高一物理必修二第六章《圓周運(yùn)動(dòng)》課后練習(xí)(有答案解析)
評(píng)論
0/150
提交評(píng)論