CSS 322 – Security and Cryptography
Simplified AES
Example
1 Simplified AES Example
Lets assume the inputs for the encryption are:
• 16-bit Plaintext, P: 1101 0111 0010 1000
• 16-bit Key, K: 0100 1010 1111 0101
1.1 Key Generation
The first step is to generate the sub-keys. This is called Key Generation or Key Expansion:
The input key, K, is split into 2 words, w0 and w1:
w0 = 0100 1010
w1 = 1111 0101
The first sub-key, Key0, is in fact just the input key: Key0 = w0w1 = K
The other sub-keys are generated as follows:
w2 = w0 XOR 10000000 XOR SubNib(RotNib(w1))
(Note: RotNib() is “rotate the nibbles”, which is equivalent to swapping the nibbles)
= 0100 1010 XOR 10000000 XOR SubNib(0101 1111)
(Note: SubNib() is “apply S-Box substitution on nibbles using encryption S-Box”)
= 1100 1010 XOR SubNib(0101 1111)
= 1100 1010 XOR 0001 0111
= 1101 1101
w3
= w2 XOR w1
= 1101 1101 XOR 1111 0101
= 0010 1000
w4
= w2 XOR 0011 0000 XOR SubNib(RotNib(w3))
= 1101 1101 XOR 0011 0000 XOR SubNib(1000 0010)
= 1110 1101 XOR 0110 1010
= 1000 0111
w5
= w4 XOR w3
= 1000 0111 XOR 0010 1000
= 1010 1111
Now the sub-keys are:
Key0 = w0w1
= 0100 1010 1111 0101
Key1
= w2w3
= 1101 1101 0010 1000
Key2
= w4w5
= 1000 0111 1010 1111
1.2 Encryption
Now let’s do the encryption. There is an initial operation (Add Round Key), followed by the main Round, followed by the final Round. (Note, the main difference in the real DES is that the main Round is repeated many times).
Remember, the output of each operation is used as the input to the next operation, always operating on 16-bits. The 16-bits can be viewed as a state matrix of nibbles.
1.2.1 Add Round 0 Key
Plaintext XOR Key1
= 1101 0111 0010 1000 XOR
0100 1010 1111 0101= 1001 1101 1101 1101
1.2.2 Round 1
Nibble Substitution (S-boxes). Each nibble in the input is used in the Encryption S-Box to generate an output nibble.
Input = 1001 1101 1101 1101
utput = 0010 1110 1110 1110
Shift Row. Swap 2nd nibble and 4th nibble (note, in this example, its not so easy to see since 2nd and 4th nibbles are the same!)
= 0010 1110 1110 1110
Mix Columns. Apply the matrix multiplication with the constant matrix, Me, using GF(24 ). For GF(24 ), the addition operation is simply an XOR, and for the multiplication operation you can use a lookup table.
Me = 1 4
4 1
S = 0010 1110 = S00’ S01’
1110 1110 S10’ S11’
S’ = Me x S
S00’
= 0010 XOR (4 x 1110)
= 0010 XOR (4 x E)
= 0010 XOR D
= 0010 XOR 1101
= 1111
S10’
= (4 x 0010) XOR 1110
= 1000 XOR 1110
= 0110
S01’
= 1110 XOR (4 x 1110)
= 1110 XOR (4 x E)
= 1110 XOR 1101
= 0011
S11’
= (4 x 1110) XOR 1110
= 1101 XOR 1110
= 0011
utput = S00’ S10’ S01’ S11’
= 1111 0110 0011 0011
Add Round 1 Key.
= 1111 0110 0011 0011 XOR
1101 1101 0010 1000
= 0010 1011 0001 1011
1.2.3 Final Round
Nibble Substitution (S-boxes)
= 1010 0011 0100 0011
Shift Row (2nd and 4th)
= 1010 0011 0100 0011
Add Round 2 Key
1010 0011 0100 0011 XOR
1000 0111 1010 1111
= 0010 0100 1110 1100
Now we have the final ciphertext.
Ciphertext = 0010 0100 1110 1100
1.3 Decryption
Now lets decrypt. Note that we use the same keys generated during the encryption (that is, the decryptor would generate the round sub-keys using the input key K, using the encryption S-Box).
Add Round 2 Key
0010 0100 1110 1100 XOR
1000 0111 1010 1111
= 1010 0011 0100 0011
Inverse Shift Row (same as normal)
= 1010 0011 0100 0011
Inverse Nibble Sub (use the inverse or decryption S-box)
= 0010 1011 0001 1011
Add Round 1 Key
= 0010 1011 0001 1011 XOR
1101 1101 0010 1000
= 1111 0110 0011 0011
Inverse Mix Columns
S = S00 S01
S10 S11
= 1111 0011
0110 0011
S’
= S00’ S01’
S10’ S11’
= 9 x S00 XOR 2 x S10 9 x S01 XOR 2 x S11
2 x S00 XOR 9 x S10 2 x S01 XOR 9 x S11
S00’
= (9 x 1111) XOR (2 x 0110)
= 9 x F XOR 2 x 6
= E XOR C
= 1110 XOR 1100
= 0010
S10’
= 2 x 1111 XOR 9 x 0110
= 2 x F XOR 9 x 6
= D XOR 3
= 1101 XOR 0011
= 1110
S01’
= 9 x 0011 XOR 2 x 0011
= 9 x 3 XOR 2 x 3
= 8 XOR 6
= 1000 XOR 0110
= 1110
S11’ = 2 x 0011 XOR 9 x 0011
= 1110
utput = 0010 1110 1110 1110
Inverse Shift Row
= 0010 1110 1110 1110
Inverse Nibble Sub
= 1001 1101 1101 1101
Add Round 0 Key
= 1001 1101 1101 1101 XOR
0100 1010 1111 0101
= 1101 0111 0010 1000
Plaintext = 1101 0111 0010 1000
riginal = 1101 0111 0010 1000
The decryption worked!
版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。