- 在线时间
- 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每一个圈变换由以下三个层组成:: w# S, U; l P
非线性层——进行Subbyte变换;
5 {! Q. a& R/ b* X" b线行混合层——进行ShiftRow和MixColumn运算;3 o, l" O+ T6 Z& \) w% ^8 J1 Z
密钥加层——进行AddRoundKey运算。
2 a+ O# @5 b7 o- X2 {7 G① Subbyte变换是作用在状态中每个字节上的一种非线性字节转换,可以通过计算出来的S盒进行映射。: O/ }6 y% e( m1 j
② ShiftRow是一个字节换位。它将状态中的行按照不同的偏移量进行循环移位,而这个偏移量也是根据Nb的不同而选择的[3]。
1 S" v+ P6 C* K- I2 ~" Z③ 在MixColumn变换中,把状态中的每一列看作GF(28)上的多项式a(x)与固定多项式c(x)相乘的结果。 b(x)=c(x)*a(x)的系数这样计算:
& t: d7 ^; W! z& i; o6 z: q
3 v) Y: I7 _0 v3 O0 x*运算不是普通的乘法运算,而是特殊的运算,即 b(x)=c(x)·a(x)(mod x4+1) 对于这个运算 b0=02。a0+03。a1+a2+a3 令xtime(a0)=02。a0
6 m$ M; n( K- L/ K. v; b
8 r4 C X) }0 U# \其中,符号“。”表示模一个八次不可约多项式的同余乘法[3]。
1 P( n! s: ]0 o4 N9 X+ O* A: M. I- M
( G" i8 C$ u* Z+ v. I
. p2 c4 h* H8 i对于逆变化,其矩阵C要改变成相应的D,即b(x)=d(x)*a(x)。$ P: T. J8 \( i
④ 密钥加层运算(addround)是将圈密钥状态中的对应字节按位“异或”。$ V) A. N8 N; X; O, }
⑤ 根据线性变化的性质[1],解密运算是加密变化的逆变化。这里不再详细叙述。; n: M# j1 D# R+ l4 f0 d
二、轮变化 2 ?6 l* |* e9 _1 P, v9 z
) ~% n/ s# E$ k* C# }
对不同的分组长度,其对应的轮变化次数是不同的,如表1所列。7 [9 w4 n1 o& J% y9 J2 r! |
0 k8 N `8 T+ K# G2 b
9 C0 J4 Y0 L0 d4 k
" M* |9 L8 j( ^* j
三、密钥扩展 # _1 f q; J* q) N
9 w* y2 ~4 d9 u) S0 k7 n5 V
AES算法利用外部输入密钥K(密钥串的字数为Nk),通过密钥的扩展程序得到共计4(Nr+1)字的扩展密钥。它涉及如下三个模块:9 C5 i$ ?8 W) o
3 F6 ?# g9 p# ^8 O① 位置变换(rotword)——把一个4字节的序列[A,B,C,D]变化成[B,C,D,A];8 L4 z/ A7 ?( E) F, O' \
$ g: }# E. N9 l0 U② S盒变换(subword)——对一个4字节进行S盒代替;3 v( [6 E3 U6 V: C5 T, c
- A9 u$ E, f) o0 \- f) r- b% k
③ 变换Rcon——Rcon表示32位比特字[xi-1,00,00,00]。
6 O7 e* S! a5 o* |1 N8 |0 L( j, u' X& T: S. L1 l; p
这里的x是(02),如 Rcon[1]=[01000000];Rcon[2]=[02000000];Rcon[3]=[04000000]…… 2 `% ?5 `. i0 R: n9 T; Y# I
, a2 x, z" [* @ q% o) I& E扩展密钥的生成:扩展密钥的前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]。# c" [% W2 W; o* [' U$ z' x
/ |7 Y3 \. |! P1 Z7 C; n% Q( OAES的加密与解密流程。
P5 I, |) Z2 U" _) a3 g' Q0 A' S
|
|