DES加密实验报告
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
网络安全作业
题目 des
学号
专业及班级
姓名
日期 2012.04.14 加密算法网络工程0902班
一.des简介:
des是一个分组密码算法,使用64位密钥(除去8位奇偶校验,实际密钥长度为56 位)对64比特的数据分组(二进制数据)加密,产生64位密文数据。des是一个对
称密码体制,加密和解密使用同意密钥,解密和加密使用同一算法(这样,在硬件与软
件设计时有利于加密单元的重用)。des的所有的保密性均依赖于密钥。
二. des算法过程:
1. des的加密过程:
第一阶段:初始置换ip。在第一轮迭代之前,需要加密的64位明文首先通过初始置换
ip
的作用,对输入分组实施置换。最后,按照置换顺序,des将64位的置换结果分为左右
两部分,第1位到第32位记为l0,第33位到第64位记为r0。
第二阶段:16次迭代变换。des采用了典型的feistel结构,是一个乘积结构的迭代密
码
算法。其算法的核心是算法所规定的16次迭代变换。des算法的16才迭代变换具有相
同的结构,每一次迭代变换都以前一次迭代变换的结果和用户密钥扩展得到的子密钥ki 作为输入;每一次迭代变换只变换了一半数据,它们将输入数据的右半部分经过函数f 后将其输出,与输入数据的左半部分进行异或运算,并将得到的结果作为新的有半部分,
原来的有半部分变成了新的左半部分。用下面的规则来表示这一过程(假设第i次迭代
所
得到的结果为liri): li = ri-1; ri = li-1⊕f(ri-1,ki);在最后一轮左与右半部分
并未变
换,而是直接将r16 l16并在一起作为未置换的输入。
第三阶段:逆(初始)置换。他是初始置换ip的逆置换,记为ip-1。在对16次迭代
的
结果(r16 l16)再使用逆置换ip-1后,得到的结果即可作为des加密的密文y输出,
即y = ip-1 (r16 l16)。
2. des解密过程:
des的解密算法与其加密算法使用的算法过程相同。两者的不同之处在于解密时子密钥ki的使用顺序与加密时相反,如果子密钥为k1k2…k16,那么解密时子密钥的使用
顺序为k16k15…k1,即使用des解密算法进行解密时,将以64位密文作为输入,第1 次迭代运算使用子密钥k16,第2次迭代运算使用子密钥k15,……,第16 次迭代使
用子密钥k1,其它的运算与加密算法相同。这样,最后输出的是64位明文。
三. des代码实现(程序): 1.新建头文件des_encode.h 内容如下:
void encodemain(); //encodemain function void decodemain(); //sorry ,it has not used void decode(int *str,int *keychar); //decode :input 8 chars,8 keychars
void encode(int *str,int *keychar); //encode: input 8 chars,8 keychars void keybuild(int *keychar); //create key array void strtobin(int *midkey,int *keychar); //change into binary void keycreate(int *midkey2,int movebit,int i); //call by keybuild void encodedata(int *ldata,int *rdata,int *srt); //encodedata function void f(int *rdata,int *key); //f function void expand(int *rdata,int *rdatap); //expand function void exchanges(int *rdatap,int *rdata); //s-diagram change void exchangep(int *rdata); //p change void fillbin(int *rdata,int n,int s);
void decodedata(int *str,int *ldata,int *rdata); //decodedata from
binary
int ip1[]={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 };
int ip2[]={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 };
ints[][4][16]={{{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} },{
{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} },{
{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} },{
{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} },{