数学建模社区-数学中国
标题:
AES加密算法的若干个问题?
[打印本页]
作者:
wangzheng3056
时间:
2013-8-6 09:36
AES每一个圈变换由以下三个层组成:
/ o$ s' E, B9 F$ H
非线性层——进行Subbyte变换;
+ q! K1 {$ w3 O3 n
线行混合层——进行ShiftRow和MixColumn运算;
, H6 t! |5 Z0 o$ }! F
密钥加层——进行AddRoundKey运算。
" t' C) `! D, D0 b$ E$ e
① Subbyte变换是作用在状态中每个字节上的一种非线性字节转换,可以通过计算出来的S盒进行映射。
3 k3 z$ z8 T$ X9 Y" T) l
② ShiftRow是一个字节换位。它将状态中的行按照不同的偏移量进行循环移位,而这个偏移量也是根据Nb的不同而选择的[3]。
7 T# q' |# O. |9 r$ S
③ 在MixColumn变换中,把状态中的每一列看作GF(28)上的多项式a(x)与固定多项式c(x)相乘的结果。 b(x)=c(x)*a(x)的系数这样计算:
' | J9 e: @6 E; ], [6 U
% O: l3 k; q& q4 T
*运算不是普通的乘法运算,而是特殊的运算,即 b(x)=c(x)·a(x)(mod x4+1) 对于这个运算 b0=02。a0+03。a1+a2+a3 令xtime(a0)=02。a0
9 m; S5 S, Z3 L3 `
; o+ e0 }6 L+ q0 H( G' ^
其中,符号“。”表示模一个八次不可约多项式的同余乘法[3]。
' k6 y& F$ v3 N
7 y* m: v0 |5 l* T4 U1 V$ O. [
2013-8-6 09:34 上传
下载附件
(10.42 KB)
8 N8 c, f# i8 V* x6 _0 o6 @
2 L% b1 t2 |+ r
对于逆变化,其矩阵C要改变成相应的D,即b(x)=d(x)*a(x)。
/ T2 n/ e5 K8 ?8 v; P
④ 密钥加层运算(addround)是将圈密钥状态中的对应字节按位“异或”。
P% [$ K1 p; f( f, I% P( D- A8 N
⑤ 根据线性变化的性质[1],解密运算是加密变化的逆变化。这里不再详细叙述。
' b$ W( y2 o' a9 c# s7 D8 M
二、轮变化
' c# R7 c% I/ k4 X4 o
9 {/ A# q/ g2 j9 r$ K
对不同的分组长度,其对应的轮变化次数是不同的,如表1所列。
3 S" }7 E1 _, H, L
- @5 m2 I$ a0 f: d j' P
2013-8-6 09:35 上传
下载附件
(18.07 KB)
: K* M. }2 C" Y+ \: e4 Y: Q' a
+ t' b0 U3 O' z: F; d& Q) v) h7 J
三、密钥扩展
7 u+ d5 |+ F2 P$ S8 V
' p9 L* z* d$ o2 R' b L2 S
AES算法利用外部输入密钥K(密钥串的字数为Nk),通过密钥的扩展程序得到共计4(Nr+1)字的扩展密钥。它涉及如下三个模块:
3 V* m- H, o! Z$ `8 w/ B0 V' m
, w8 @# c( n5 W3 r
① 位置变换(rotword)——把一个4字节的序列[A,B,C,D]变化成[B,C,D,A];
/ r2 H! k/ M, O8 V4 U9 G
( y5 c& c0 H0 b3 Q, K( B5 h+ S
② S盒变换(subword)——对一个4字节进行S盒代替;
' c0 b4 H. g7 U" f2 x
]7 t5 k4 y- v k
③ 变换Rcon
——Rcon
表示32位比特字[xi-1,00,00,00]。
+ ~ c* v( R# \8 P0 P
; K7 y7 X* y6 \' ]( O
这里的x是(02),如 Rcon[1]=[01000000];Rcon[2]=[02000000];Rcon[3]=[04000000]……
" o9 ?" n$ A/ h/ J
2 s% s8 |: E3 A6 C. ^ f% F2 [
扩展密钥的生成:扩展密钥的前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]。
; R5 X9 ~0 `, S1 E
' [( G2 I$ c1 Q; T0 t3 y
AES的加密与解密流程。
5 x) w5 x; _! G
- u) B1 x" R e/ v$ T
2013-8-6 09:36 上传
下载附件
(73.79 KB)
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5