DES算法详解和代码 - IP置换
生活随笔
收集整理的這篇文章主要介紹了
DES算法详解和代码 - IP置换
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
DES算法,IP置換的功能是把輸入的64位數據塊按位重新組合,并把輸出分為L0、R0兩部分,每部分各長32位,其置換規則見下表:
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,45,37,29,21,13,5,63,55,47,39,31,23,15,7,
即將輸入的第58位換到第一位,第50位換到第2位,...,依此類推,最后一位是原來的第7位。L0、R0則是換位輸出后的兩部分,L0是輸出的左32位,R0 是右32位,例
如:設置換前的輸入值為D1D2D3......D64,則經過初始置換后的結果為:L0=D58D50...D8;R0=D57D49...D7。
其典型C代碼實現如下:
定義IP置換表如上表,char類型數組,長度為64;
然后,在從0到64循環,把源數組的數據按IP置換表的內容填到目的數組,即實現了IP置換;
// initial permutation (IP) const static char IP_Table[64] = {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, 45, 37, 29, 21, 13, 5, 63, 55, 47, 39, 31, 23, 15, 7 };void DES_InitialPermuteData(char* src,char* dst) {//IPint i=0;for(i=0;i<64;i++){dst[i] =src[IP_Table[i]-1];} }
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,45,37,29,21,13,5,63,55,47,39,31,23,15,7,
即將輸入的第58位換到第一位,第50位換到第2位,...,依此類推,最后一位是原來的第7位。L0、R0則是換位輸出后的兩部分,L0是輸出的左32位,R0 是右32位,例
如:設置換前的輸入值為D1D2D3......D64,則經過初始置換后的結果為:L0=D58D50...D8;R0=D57D49...D7。
其典型C代碼實現如下:
定義IP置換表如上表,char類型數組,長度為64;
然后,在從0到64循環,把源數組的數據按IP置換表的內容填到目的數組,即實現了IP置換;
// initial permutation (IP) const static char IP_Table[64] = {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, 45, 37, 29, 21, 13, 5, 63, 55, 47, 39, 31, 23, 15, 7 };void DES_InitialPermuteData(char* src,char* dst) {//IPint i=0;for(i=0;i<64;i++){dst[i] =src[IP_Table[i]-1];} }
總結
以上是生活随笔為你收集整理的DES算法详解和代码 - IP置换的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: TCP/IP协议-概念、应用、开发、Ha
- 下一篇: MyEclipse Web 项目的图标和