- 在线时间
- 490 小时
- 最后登录
- 2024-2-3
- 注册时间
- 2013-2-28
- 听众数
- 117
- 收听数
- 46
- 能力
- 268 分
- 体力
- 39235 点
- 威望
- 1340 点
- 阅读权限
- 255
- 积分
- 31237
- 相册
- 2
- 日志
- 0
- 记录
- 0
- 帖子
- 1388
- 主题
- 937
- 精华
- 0
- 分享
- 0
- 好友
- 111
升级   0% TA的每日心情 | 衰 2020-10-25 11:55 |
|---|
签到天数: 264 天 [LV.8]以坛为家I
- 自我介绍
- 内蒙古大学计算机学院
 群组: 2013年数学建模国赛备 |
AES每一个圈变换由以下三个层组成:" L% H G& M: N- j1 m0 Q
非线性层——进行Subbyte变换;
# `# M8 l6 O" b3 v# S1 {线行混合层——进行ShiftRow和MixColumn运算;* f+ }& |+ N% B% }
密钥加层——进行AddRoundKey运算。1 ]0 {% W0 E5 c3 U! l# h& M
① Subbyte变换是作用在状态中每个字节上的一种非线性字节转换,可以通过计算出来的S盒进行映射。
4 t* O% p) { p7 ^5 n② ShiftRow是一个字节换位。它将状态中的行按照不同的偏移量进行循环移位,而这个偏移量也是根据Nb的不同而选择的[3]。9 b) d- L, j8 b! L3 c8 i
③ 在MixColumn变换中,把状态中的每一列看作GF(28)上的多项式a(x)与固定多项式c(x)相乘的结果。 b(x)=c(x)*a(x)的系数这样计算:# F6 Z8 D' H* U
B* L* S+ M& a, H6 v1 N
*运算不是普通的乘法运算,而是特殊的运算,即 b(x)=c(x)·a(x)(mod x4+1) 对于这个运算 b0=02。a0+03。a1+a2+a3 令xtime(a0)=02。a0) r& N) w3 C+ p8 l: t6 y
5 K$ A& S$ x3 E
其中,符号“。”表示模一个八次不可约多项式的同余乘法[3]。9 a8 T9 F9 A" \1 `& `# V6 M/ t
3 a" ]& K, I; T3 }+ ?2 P# ~ z; V
( z7 Y- m/ N J( o6 G! _5 \9 y
# e1 d4 z' e; h: \! [+ E
对于逆变化,其矩阵C要改变成相应的D,即b(x)=d(x)*a(x)。4 d3 [. K6 g8 s
④ 密钥加层运算(addround)是将圈密钥状态中的对应字节按位“异或”。
F2 Y; l, i; i" B⑤ 根据线性变化的性质[1],解密运算是加密变化的逆变化。这里不再详细叙述。% q- O9 V/ o( @
二、轮变化 , d+ K4 M, w f4 q$ q5 n1 [; u7 m3 }, c
3 r- ~. E" ~7 i对不同的分组长度,其对应的轮变化次数是不同的,如表1所列。( ^6 `. u; h6 J+ C% U* A0 |* ~. d
' M& ` }- P! C5 {4 V
" a+ ^ m, j: }# `3 Q; r
# O& N7 K" A2 g& ]+ ]& L9 F, E三、密钥扩展 ' ]! E3 W K4 s4 [5 P9 n* E
+ z( Z; Q9 w7 \2 f; lAES算法利用外部输入密钥K(密钥串的字数为Nk),通过密钥的扩展程序得到共计4(Nr+1)字的扩展密钥。它涉及如下三个模块:
L/ n' B' c8 X! b. Z, n' B# g* q- ?' {0 [- [7 D5 ^
① 位置变换(rotword)——把一个4字节的序列[A,B,C,D]变化成[B,C,D,A];
6 ~* C+ k3 S9 j" I% S2 x
3 g, H6 e' B8 M② S盒变换(subword)——对一个4字节进行S盒代替;4 j, L- `/ f' }" ]8 ~# ?+ J/ a8 Q
* ]" W5 W0 O0 Y! g% e③ 变换Rcon——Rcon表示32位比特字[xi-1,00,00,00]。
" M' d4 K8 C9 B+ a+ D) s6 s7 ~4 P: o$ F4 S
这里的x是(02),如 Rcon[1]=[01000000];Rcon[2]=[02000000];Rcon[3]=[04000000]……
' X, [9 s9 E9 K x2 x) R: V, s( l+ }9 L5 }8 W4 J1 B
扩展密钥的生成:扩展密钥的前Nk个字就是外部密钥K;以后的字W[[i]]等于它前一个字W[[i-1]]与前第Nk个字W[[i-Nk]]的“异或”,即W[[i]]=W[[i-1]]W[[i- Nk]]。但是若i为Nk的倍数,则W[i]=W[i-Nk]Subword(Rotword(W[[i-1]]))Rcon[i/Nk]。; M; }# i6 a& }. k6 f9 V4 r1 V1 C
5 e' W3 d( \1 ^- XAES的加密与解密流程。
" d5 e) S/ a! Y( P3 h% t& [; d- J' E, W9 q/ r
|
|