DES算法
介绍
DES算法属于对称加密算法中的分组加密算法。
分组密码
分组密码是将明文信息编码表示后的数字序列,划分成长度相等的组,每组分别在秘钥的控制下变换成等长的数组数字序列。
流密码
流密码是明文和密钥长度一致,一一进行异或运算,可以得出密文。
DES加密流程分析
DES加密步骤稍有复杂。
明文处理
首先我们的明文数据也是要进行填充和分组操作的。DES算法分组的大小是64位,如果明文不足64位,需要填充0直到长度达到64位;如果超过64位,则使用分组模式进行分组加密。
IP置换(初始置换)
这里有一个初始置换表
1 | 58 50 42 34 26 18 10 2 |
明文长度是64位的,这个表里有64份数据,将这个表中的数据作为索引进行置换,得到一份新的数据。将这份新数据分为左右两部分各32位,记为L0和R0。
轮函数
- L1的生成
L1直接由R0赋值所得,即L1=R0。 - R1的生成
R1的生成就较为复杂了。
E扩展置换
32位的R0和48位的密钥K作为参数传递给轮函数F。(这里的密钥K是经过计算生成的,过程在后面附加)。
第一步要做的就是把32位的R0扩展为48位。
这个过程可以用E扩展置换表来理解:
1 | 32 1 2 3 4 5 |
中间四列是原始的32位数据,把它分为了8组,每份4组数据,每组数据的前后各添加一位数据,这两位数据分别是上一组数据的最后一位和下一组数据的第一位。由此得到48位的数据。这样就扩展完成了。
S盒压缩处理
扩展后的48位数据和密钥K进行异或,得到48位的结果作为S盒的输入。
- S盒 将48位输入等分为8块,每块6位输入压缩为4位输出。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47S1:
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 2 15 12 9 7 3 13 8 10 6 5 11 0 14
1 14 8 13 6 2 11 15 12 9 7 3 10 5 0 4
S2:
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 6 10 2 8 5 14 12 11 15 1
4 1 2 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
S4:
7 13 10 1 3 12 14 8 11 5 0 6 9 4 2 15
2 1 14 7 4 11 8 13 6 15 3 0 9 10 5 12
15 12 8 2 4 9 1 7 5 11 3 14 10 0 6 13
6 11 13 0 8 5 10 3 4 7 15 14 1 2 12 9
S5:
10 13 0 7 9 14 6 3 1 2 15 8 5 11 12 4
13 7 0 9 3 4 6 10 1 2 8 5 11 14 15 12
1 14 8 13 6 2 11 15 12 9 7 3 10 5 0 4
11 12 14 1 2 13 4 5 3 8 6 15 9 0 10 7
S6:
2 8 11 6 15 12 1 13 3 10 4 9 5 0 14 7
1 2 4 3 10 13 7 8 5 15 6 9 11 14 0 12
7 13 10 4 8 5 15 9 6 1 2 14 0 3 11 12
6 11 13 8 1 4 10 7 9 5 0 15 14 2 3 12
S7:
13 2 14 4 1 7 15 11 10 3 6 9 12 0 8 5
4 1 2 11 10 13 7 8 15 9 12 5 3 0 14 6
1 14 7 11 4 2 13 1 5 0 15 6 8 9 10 3
2 12 4 1 7 10 11 13 15 9 3 5 0 14 8 6
S8:
14 11 2 12 4 15 1 7 8 13 6 5 10 9 3 0
3 12 6 7 14 11 13 5 0 1 15 4 8 9 10 2
6 11 13 8 1 4 10 7 9 5 0 15 14 2 3 12
13 7 0 9 3 4 6 10 2 8 5 14 12 11 15 1
每个S盒都包含4行和16列,共有64个数据。
将原始六位数据的头尾数据结合在一起为行数,中间数据结合在一起为列数。
根据索引在S盒中找到对应的4位二进制数,就是S盒的输出。
最后能得到32位的数据。
轮函数P盒置换
S和的输出作为P盒的输出,得到32位的结果,这个结果就是F轮函数的结果。
这个结果与L0进行异或,所得结果赋值给R1。
逆置换
经过一次轮函数计算得到了L1和R1。加下来以同样的方式计算得到R1R16,L1L16,一共经过16次轮函数的计算。
最终得到L16和R16。
把L16和R16拼接在一起,经过逆置换的置换,得到最终的DES算法加密的结果。
逆置换表:
子密钥K的生成
首先是长度为64位的主密钥,经过PC-1表置换,去除校验位,得到56位的数据。
PC-1置换表
取前28位数据记为C0,后28位数据记为D0。
移位
接下来对C0和D0进行循环左移操作
移位表
C1和D1是由C0和D0左移一位得到的,C2和D2是由C1和D1左移一位得到的。
由此得到C1-C16,D1-D16。
把C1和D1拼接在一起,C2和D2拼接在一起…C16和D16拼接在一起。
经过PC-2表的置换,得到K1~K16,十六个48位的子密钥。这里的子密钥就是在F轮函数中S盒压缩使用的子密钥K。
PC-2置换表