DES算法的原理與實現(xiàn)_第1頁
DES算法的原理與實現(xiàn)_第2頁
DES算法的原理與實現(xiàn)_第3頁
DES算法的原理與實現(xiàn)_第4頁
DES算法的原理與實現(xiàn)_第5頁
免費預(yù)覽已結(jié)束,剩余13頁可下載查看

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

1、實驗項目與實驗報告(2 )學(xué)科:信息與網(wǎng)絡(luò)安全 學(xué)號:姓名:時間:月 日實驗名稱:DES算法的原理與實現(xiàn) 實驗?zāi)康模?.熟悉DES算法的實現(xiàn)程序和具體應(yīng)用,加深對DESM法的了解。實驗內(nèi)容:(寫出實驗內(nèi)容要點或相關(guān)理論準(zhǔn)備、實驗估計)、DES1法的簡介DES 算法為密碼體制中的對稱密碼體制,又被稱為美國數(shù)據(jù)加密標(biāo)準(zhǔn),是1972年美國BM公司研制的對稱密碼體制加密算法。明文按64位進行分組,密鑰長 64位,密鑰事實上是 56位參與DES運算(第8、16、24、32、40、48、56、64位是校驗位,使得每個密鑰都有奇數(shù)個1)分組后的明文組和56位的密鑰按位代替或交換的方法形成密文組的加密方法。

2、1、基本原理其入口參數(shù)有三個:key、data、mode Key為加密解密使用的密鑰,data為加密解密的數(shù)據(jù),mode為其工作模式。當(dāng)模式為加密模式時,明文按照 64為進行分組,形成明文組, key用于對數(shù)據(jù) 加密,當(dāng)模式為解密模式時,key用于對數(shù)據(jù)解密。實際運用中,密鑰只用到了 64位中的56位,這樣才具有高的安全性。密鑰單輪運算位的擴展48位異或> 32位異或右半部分輸出64位密文16輪運算圖1 DES算法結(jié)構(gòu)2、DES特點DES算法具有極高安全性,到目前為止,除了用窮舉搜索法對DES算法進行攻擊外,還沒有發(fā)現(xiàn)更有效的辦法。而 56位長的密鑰的窮舉空間為256 ,這意味著如果一臺

3、計算機的速度是每一秒鐘檢測一百萬個密鑰,則它搜索完全部密鑰就需要將近2285年的時間,可見,這是難以實現(xiàn)的。然而,這并不等于說 DES是不可破解的。而實際上,隨著硬件技術(shù)和Intemet的發(fā)展,其破解的可能性越來越大,而且,所需要的時間越來越少。為了克服DES密鑰空間小的缺陷,人們又提出了三重DES的變形方式。3、主要流程DES算法把64為的明文輸入塊變?yōu)?64位的密文輸入塊,它所使用的密鑰也是 64位,整個算法 的主要流程圖如下:(1 )置換規(guī)則表其功能是把輸入的數(shù)據(jù)塊按位重新組合,并把輸出分為L0、R0兩部分,每部分各長32位,其置換規(guī)則見下表:58,50,42,34,26,18,10,2

4、,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,45,37,29,21,13,5,63,55,47,39,31,23,15,7,即將輸入的第58位換到第一位,第50位換到第2位,依此類推,最后一位是原來的第7位。L0、 R0則是換位輸出后的兩部分,L0是輸出的左32位,R0是右32位,例:設(shè)置換前的輸入值為D1D2D3D64 ,則經(jīng)過初始置換后的結(jié)果為:L0=D58D50D8 ; R0=D57D49D7

5、 。經(jīng)過16次迭代運算后。得到 L16、R16,將此作為輸入,進行逆置換,即得到密文輸出。逆置換 正好是初始置換的逆運算。例如,第1位經(jīng)過初始置換后,處于第 40位,而通過逆置換,又將第 40位換回到第1位,其逆置換規(guī)則如下表所示: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,58 26,33,1,41,9,49,17,57,25,(

6、2)放大換位表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,(3)單純換位表16,7,20,21,29,12,28,17,1,15,23,26,5,18,31,10,2,8,24,14,32,27,3,9,19,13,30,6,22,11,4,25,(4)功能表在f(Ri,Ki )算法描述圖中,S1,S2.S8為選擇函數(shù),其功能是把 48bit數(shù)據(jù)變?yōu)?2bit數(shù)據(jù)。下面 給出選擇函

7、數(shù)Si(i=1,28 )的功能表:選擇函數(shù)Si51: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,52: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, 1

8、3,8,10,1,3,15,4,2,11,6,7,12,0,5,14,9,53:10,0,9,14,6,3,15,5,1,13,12,7,11,4,2,8,13,7,0,9,3,4,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,54: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,

9、14,5,2,8,4, 3,15,0,6,10,1,13,8,9,4,5,11,12,7,2,14,55: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,56:12,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,1

10、2,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,57:4,11,2,14,15,0,8,13,3,12,9,7,5,10,6,1,13,0,11,7,4,9,1,10,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,58: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,

11、4,1,9,12,14,2,0,6,10,13,15,3,5,8,2,1,14,7,4,10,8,13,15,12,9,0,3,5,6,11,在此以S1為例說明其功能,我們可以看到:在 S1中,共有4行數(shù)據(jù),命名為0, 1、2、3行;每 行有16列,命名為0、1、2、3,14、15列?,F(xiàn)設(shè)輸入為:D=D1D2D3D4D5D6令:歹U =D2D3D4D5行=口1口6然后在S1表中查得對應(yīng)的數(shù),以4位二進制表示,此即為選擇函數(shù)S1的輸出。下面給出子密鑰Ki (48bit)的生成算法。(5)子密鑰的生成算法從子密鑰Ki的生成算法描述圖中我們可以看到: 初始Key值為64位,但DES算法規(guī)定,其中第

12、8、16、64位是奇偶校驗位,不參與 DES運算。故Key實際可用位數(shù)便只有56位。即:經(jīng)過縮 小選擇換位表1的變換后,Key的位數(shù)由64位變成了 56位,此56位分為C0、D0兩部分,各28位, 然后分別進行第1次循環(huán)左移,得到 C1、D1 ,將C1 (28位)、D1 (28位)合并得到56位,再經(jīng)過縮 小選擇換位2,從而便得到了密鑰 K0 (48位)。依此類推,便可得到 K1、K2、K15 ,不過需要 注意的是,16次循環(huán)左移對應(yīng)的左移位數(shù)要依據(jù)下述規(guī)則進行:(6)循環(huán)左移位數(shù)1,122,22221,2222221以上介紹了 DES算法的加密過程。DES算法的解密過程是一樣的,區(qū)別僅僅在于

13、第一次替代時 用子密鑰K15,第二次K14、,最后一次用 K0,算法本身并沒有任何變化。二、源程序與代碼實現(xiàn)1、源代碼#include <stdio.h> #include <conio.h>/* initial permutation P*/;/* final permutation F */#define u8 unsigned char const static u8 ip64= 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,

14、 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, 45, 37, 29, 21, 13, 5,63, 55, 47, 39, 31,23, 15, 7 const static u8 fp64= 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,

15、20, 60, 28,35, 3, 43, 11,51, 19, 59, 27,34, 2, 42, 10, 50, 18, 58, 26,33, 1,41, 9, 49, 17, 57, 25;/*unused*/const static u8 ei48 = 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

16、;const static u8 pc156= 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;const static u8 totrot16*/=1,1,2,2,2,2,2,2,1,2,2,2,2,2,2,1expansion ope

17、ration matrix */*/* permuted choice table (key) */*number left rotations;rwo:of pc1const static u8 pc248= 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;/* permuted choice key

18、 (table) */const static u8 si864/* 48->32 bit compression tables*/=/* 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,/* S2 */15, 1,

19、8,14,6,11,3, 4,9,7,2, 13, 12,0,5, 10,16, 13, 4,7,15,2,8, 14,12,0,1, 10,6,9,11, 5,2, 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 */14, 0, 9, 14, 6, 3, 15, 5, 1, 13, 12, 7, 11, 4, 2, 8,15, 7, 0, 9, 3, 4, 6, 10, 2, 8, 5, 14, 12, 11, 15, 1,16, 6, 4, 9,8,15,

20、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, 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,

21、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, 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,

22、 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, 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,/*

23、 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,8,2, 1, 14,7,4,10,8, 13,15,12,9,0,3,5,6, 11;const static u8 p32i32/* 32-bit permutation function */=16, 7, 20, 21,29, 12, 28, 17,1, 15, 23, 26,5, 18, 31, 10,2, 8, 24, 14,32

24、, 27, 3, 9,19, 13, 30, 6,22, 11, 4, 25;const static u8 bitmap8 = 0x80, 0x40, 0x20, 0x10, 0x08, 0x04, 0x02, 0x01;void main()u8 Key8, Input8, Output8;/* Key8,Input8, Output8 ;*/u8 Subkey1648;u8 Data_Left32, Data_Right32;int k;void Generate_Subkey( u8 Key8, u8 Subkey1648);void DES_E(u8 Input8, u8 Outpu

25、t8, u8 Data_Left32, u8 Data_Right32, u8 Subkey16 48);void DES_D(u8 Input8, u8 Output8, u8 Data_Left32, u8 Data_Right32, u8 Subkey16 48);printf("nPlease input a key of 8 letters:n");fflush(stdin);for (k=0;k<8;k+)scanf("%c”,&Keyk);printf("nPlease input a plaintext of 8 lette

26、rs:n");fflush(stdin);for(k=0;k<8;k+)scanf("%c",&Inputk);Generate_Subkey(Key, Subkey);DES_E(Input, Output, Data_Left, Data_Right, Subkey);printf("nthe Plaintext is :n");for(k=0;k<8;k+)printf("%c",Inputk);printf("nthe cipher in hex is :n");for(k=0

27、;k<8;k+)printf("%#x ",Outputk);DES_D(Output, Input, Data_Right, Data_Left, Subkey);printf("nnthe cipher in char is :n");for(k=0;k<8;k+)printf("%c",Outputk);printf("nthe Plaintext is :n");for(k=0;k<8;k+)printf("%c",Inputk);void Generate_Subke

28、y( u8 Key8, u8 Subkey1648)u8 temp64;u8 temp156;u8 Ci28;u8 Di28;u8 bittemp;int n, i, j ;for ( i=0; i<8; i+ )printf("%#x'n",Keyi);for ( j=0; j<8; j+ )if (Keyi & bitmap8-j) tempi*8+j = 1 ;else tempi*8+j = 0 ; /*set 1 or 0 to temp64 */printf("%d",tempi*8+j); printf(&quo

29、t;n");for ( i=0 ; i<56 ; i+)temp1i=temppc1i-1;for ( i=0; i<28; i+ ) Cii = temp1 i ;Dii = temp1 28+i ;for (n=0;n<16;n+)for (i=0;i<totrotn;i+)bittemp = Ci0;for ( j = 0; j <27; j+)Cij = Cij+1;Ci27 = bittemp;bittemp = Di0;for (j = 0; j <27; j+)Dij = Dij+1;Di27 = bittemp;for (i=0;i

30、<28;i+) temp1i = Cii;temp127+i = Dii;for (i=0;i<48;i+)Subkeyni = temp1 pc2i - 1 ; void Initial_Permutation( u8 Input8, u8 Data_Left32, u8 Data_Right 32)u8 temp64;int i, j ;for ( i=0; i<8; i+ )for(j=0; j<8; j+ )if (Inputi & bitmap7-j ) tempi*8+j = 1 ;else tempi*8+j = 0 ;for ( i=0; i&l

31、t;32; i+ )Data_Lefti = temp ipi - 1 ;Data_Righti = temp ip32+i - 1 ;void Inverse_Initial_Permutation(u8 Data_Left32, u8 Data_Right32, u8 Output8) u8 temp64 , temp264; int i, j ;for( i=0; i<32; i+ )temp i = Data_Lefti;tempi+32 = Data_Righti;for ( i=0; i<64; i+ )temp2i = temp fpi - 1 ;for ( i=0;

32、 i<8; i+ ) Outputi = 0 ;for ( i=0; i<8; i+ )for ( j=0; j<8; j+ )if ( temp2i*8+j) Output i |= bitmap7-j;void E_Permutation( u8 Right32, u8 temp48)int i ;for ( i=0; i<48; i+ )temp i = Right ei i - 1 ;void P_Permutation( u8 temp32, u8 f32)int i;for ( i=0; i<32; i+ )fi = temp p32ii - 1 ;v

33、oid S_Box( u8 temp48, int n )/*0<=n<8*/u8 In6, Out4;int i, j ;u8 s;for( i=0; i<6; i+ )Ini = temp n*6+i ;i = 0 ;if ( In5 ) i = 1 ;if (In0 ) i+= 2 ;if ( In4 ) j = 1 ;if ( In3 ) j+= 2 ;if ( In2 ) j+= 4 ;if ( In1 ) j+= 8 ;s = si n i*16+j ;for( i=0; i<4; i+ )if (s & bitmap7-i) temp n*4 +

34、i = 1;else temp n*4 + i = 0;void F_function( u8 Right32, u8 Subkey1648, int No, u8 f32)u8 temp48;int i ;for( i=0; i<48; i+ )tempi = 0 ;E_Permutation( Right, temp );for( i=0; i<48; i+ )tempi A= Subkey No i ;for( i=0; i<8; i+ )S_Box( temp, i );P_Permutation( temp, f );void Encript_Loop( u8 Data_Left32, u8 Data_Right32, u8 Subkey1648, int No ) u8 Temp32, temp232;int i, j;for( i=0; i<32; i+ )Temp i = Data_Left i ;Data_Left i = Data_Right i ;F_function( Data_Right, Subkey, No, temp2 );for( i=0; i<32; i+ ) D

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論