1 12 0011 3 1 12 11 7 0100 4 7 4 10 1 0101 5 10 7 13 14 0110 6 11 13 7 2 0111 7 6 1 8 13 1000 8 8 5 15 6 1001 9 5 0 9 15 1010 10 3 15 12 0 1011 11 15 10 5 9 1100 12 13 3 6 10 1101 13 0 9 3 4 1110 14 14 8 0 5 1111 15 9 6 14 3
-------- S-BOXES6
binary d1d6 => 00 01 10 11 // d2..d5 // dec 0 1 2 3 0000 0 12 10 9 4 0001 1 1 15 14 3 0010 2 10 4 15 2 0011 3 15 2 5 12 0100 4 9 7 2 9 0101 5 2 12 8 5 0110 6 6 9 12 15 0111 7 8 5 3 10 1000 8 0 6 7 11 1001 9 13 1 0 14 1010 10 3 13 4 1 1011 11 4 14 10 7 1100 12 14 0 1 6 1101 13 7 11 13 0 1110 14 5 3 11 8 1111 15 11 8 6 13
-------- S-BOXES7
binary d1d6 => 00 01 10 11 // d2..d5 // dec 0 1 2 3 0000 0 4 13 1 6 0001 1 11 0 4 11 0010 2 2 11 11 13 0011 3 14 7 13 8 0100 4 15 4 12 1 0101 5 0 9 3 4 0110 6 8 1 7 10 0111 7 13 10 14 7 1000 8 3 14 10 9 1001 9 12 3 15 5 1010 10 9 5 6 0 1011 11 7 12 8 15 1100 12 5 2 0 14 1101 13 10 15 5 2 1110 14 6 8 9 3 1111 15 1 6 2 12
-------- S-BOXES8
binary d1d6 => 00 01 10 11 // d2..d5 // dec 0 1 2 3 0000 0 13 1 7 2 0001 1 2 15 11 1 0010 2 8 13 4 14 0011 3 4 8 1 7 0100 4 6 10 9 4 0101 5 15 3 12 10 0110 6 11 7 14 8 0111 7 1 4 2 13 1000 8 10 12 0 15 1001 9 9 5 6 12 1010 10 3 6 10 9 1011 11 14 11 13 0 1100 12 5 0 15 3 1101 13 0 14 3 5 1110 14 12 9 5 6 1111 15 7 2 8 11
2.4.4.4 返回2.4.4.1直至8个数据块都被替换。 2.4.5 把B[1]至B[8] 顺序串联起来得到一个32位数。对这个数做如下变换:
bit goes to bit bit goes to bit 16 1 2 17 7 2 8 18 20 3 24 19 21 4 14 20 29 5 32 21 12 6 27 22 28 7 3 23 17 8 9 24 1 9 19 25 15 10 13 26 23 11 30 27 26 12 6 28 5 13 22 29 18 14 11 30 31 15 4 31 10 16 25 32
2.4.6 把得到的结果与L[i-1]作异或运算。把计算结果賦给R[i]。 2.4.7 把R[i-1]的值賦给L[i]。 2.4.8 从2.4.1循环执行,直到K[16]也被用到。 2.5 把R[16]和L[16] 顺序串联起来得到一个64位数。对这个数实施2.2变换的逆变换。
以上就是DES算法如何加密一段64位数据块。解密时用同样的过程,只需把16个子密钥的 顺续颠倒过来,应用的顺序为K[16],K[15],K[14],。。。。K[1]。 上一页 [1] [2] [3]
Tags:
|