- 在线时间
- 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每一个圈变换由以下三个层组成:1 G2 k. B6 e# e! a; ?
非线性层——进行Subbyte变换;. a# Z+ r" o- Y! w" O4 [+ B
线行混合层——进行ShiftRow和MixColumn运算;/ o7 ?3 y* H5 g
密钥加层——进行AddRoundKey运算。0 F" z( q6 u& `7 V
① Subbyte变换是作用在状态中每个字节上的一种非线性字节转换,可以通过计算出来的S盒进行映射。+ b( f3 Q& L6 X' e2 q* { c
② ShiftRow是一个字节换位。它将状态中的行按照不同的偏移量进行循环移位,而这个偏移量也是根据Nb的不同而选择的[3]。
: v% c6 Y0 e3 K1 K# I③ 在MixColumn变换中,把状态中的每一列看作GF(28)上的多项式a(x)与固定多项式c(x)相乘的结果。 b(x)=c(x)*a(x)的系数这样计算:
( M. p8 r$ x7 N" i, ?
6 z L0 ?! \% O c/ V# H1 Q* ] J+ E; r*运算不是普通的乘法运算,而是特殊的运算,即 b(x)=c(x)·a(x)(mod x4+1) 对于这个运算 b0=02。a0+03。a1+a2+a3 令xtime(a0)=02。a0
% n$ n" Q) Z- P4 E$ P
& d/ p# s+ c& ?其中,符号“。”表示模一个八次不可约多项式的同余乘法[3]。
8 Y) T- O4 O5 h" s1 O }4 ~5 _ z3 e1 e0 _5 y
* @" ^. e, |% c" I. d' @' f m9 |9 |* I2 `4 y. ]
对于逆变化,其矩阵C要改变成相应的D,即b(x)=d(x)*a(x)。. [+ |0 b6 R1 Y; N5 p
④ 密钥加层运算(addround)是将圈密钥状态中的对应字节按位“异或”。, C* S# S& b. L" d* N I
⑤ 根据线性变化的性质[1],解密运算是加密变化的逆变化。这里不再详细叙述。
& a2 Z! L9 a! R6 i二、轮变化 + g# N" b1 e! x& W- r0 f. K2 C8 h6 `, V
* {. x, N. a' U3 C. A对不同的分组长度,其对应的轮变化次数是不同的,如表1所列。0 w1 x5 @/ ^ x- z3 v! W, ~
( ` Y# Z- m/ F$ s4 a
# `1 d S* O3 L9 |5 F* R5 G0 x4 {: C/ x n3 ?, G
三、密钥扩展 - d' F$ ~2 D! ~- i0 T
) P3 d! V4 K! k' T1 U2 cAES算法利用外部输入密钥K(密钥串的字数为Nk),通过密钥的扩展程序得到共计4(Nr+1)字的扩展密钥。它涉及如下三个模块:4 x K5 g7 U3 Y9 T6 ~% x8 r$ m- s x
; {6 o- n% f/ ^' B3 S
① 位置变换(rotword)——把一个4字节的序列[A,B,C,D]变化成[B,C,D,A];; ]9 _% Y! F* d# \- e/ ~) l
: N) ?" |5 A) P5 k2 n D
② S盒变换(subword)——对一个4字节进行S盒代替;
( E$ n; M* ~1 W+ i6 P/ h
3 a. g+ v3 } ~9 h③ 变换Rcon——Rcon表示32位比特字[xi-1,00,00,00]。# O# D- ^( y S! o" T4 J
) j# ?( | l: L8 `5 }: l: J
这里的x是(02),如 Rcon[1]=[01000000];Rcon[2]=[02000000];Rcon[3]=[04000000]…… ( [: A3 X8 ]3 Q% @
0 U2 k: q3 T) B" K, n9 {9 R; X扩展密钥的生成:扩展密钥的前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! z, x- x% w9 `4 p! r
; k- B1 B8 L) E; x; y. ^
AES的加密与解密流程。+ ?! O6 L* ~! w: ?
# h; Y! X7 L0 Z5 Q/ E8 Z: m$ ?( k+ E9 W8 w
|
|