QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2405|回复: 2
打印 上一主题 下一主题

AES加密算法的若干个问题?

[复制链接]
字体大小: 正常 放大
1#
无效楼层,该帖已经被删除
2#
无效楼层,该帖已经被删除

937

主题

117

听众

3万

积分

升级  0%

  • TA的每日心情

    2020-10-25 11:55
  • 签到天数: 264 天

    [LV.8]以坛为家I

    自我介绍
    内蒙古大学计算机学院

    社区QQ达人 金点子奖 助人为乐奖 风雨历程奖

    群组2013年数学建模国赛备

    AES每一个圈变换由以下三个层组成:
    9 K7 _9 r. l! B( m/ D, x非线性层——进行Subbyte变换;
    & G8 g6 B% b7 e/ }; y线行混合层——进行ShiftRow和MixColumn运算;
    0 W3 [% U# x7 L密钥加层——进行AddRoundKey运算。* s; ?: |0 k) W$ P. t# u  J
    ① Subbyte变换是作用在状态中每个字节上的一种非线性字节转换,可以通过计算出来的S盒进行映射。
    3 B: X' u  g- U4 _& o0 C" A) c6 b7 a# s② ShiftRow是一个字节换位。它将状态中的行按照不同的偏移量进行循环移位,而这个偏移量也是根据Nb的不同而选择的[3]。
    - C( ^8 ?: d) S7 R4 r* h③ 在MixColumn变换中,把状态中的每一列看作GF(28)上的多项式a(x)与固定多项式c(x)相乘的结果。 b(x)=c(x)*a(x)的系数这样计算:! a! m4 g- V$ z7 L

    5 E  r& ^5 l4 v1 X) A) t*运算不是普通的乘法运算,而是特殊的运算,即 b(x)=c(x)·a(x)(mod x4+1) 对于这个运算 b0=02。a0+03。a1+a2+a3 令xtime(a0)=02。a02 s6 r' i  `7 I2 K+ G  ]

    & [4 x8 M" V# a" A0 Y+ L其中,符号“。”表示模一个八次不可约多项式的同余乘法[3]。
    % o' y$ X' ^: Q9 |& P6 ^$ k! ~- w( Y' M3 e# w1 F) x
    11.jpg
    : t7 ?: G9 y2 k) H- ~9 R
    # |  n8 Q9 K2 Q对于逆变化,其矩阵C要改变成相应的D,即b(x)=d(x)*a(x)。4 k/ x' V1 {/ h% C2 X! A; [! U( s
    ④ 密钥加层运算(addround)是将圈密钥状态中的对应字节按位“异或”。% D+ j( g( Z1 h2 L/ V) a2 @$ O
    ⑤ 根据线性变化的性质[1],解密运算是加密变化的逆变化。这里不再详细叙述。, L4 e8 \6 @) Y6 r  A; p; n5 F
    二、轮变化   8 d9 l6 j' m- M
    ( i( _* w+ v8 B  B: F% U3 h
    对不同的分组长度,其对应的轮变化次数是不同的,如表1所列。
    + Y/ v" U' Z2 |6 a( ^
    5 B  y/ P  Q) d$ @% t& k9 e7 G7 k 1.jpg
    * _- m. D, H' ^8 C+ p0 Q9 L8 f: h4 r* e6 t
    三、密钥扩展  
    , a, b9 H4 ]- G# \1 Z* O: P+ E: k: m; d/ l! K
    AES算法利用外部输入密钥K(密钥串的字数为Nk),通过密钥的扩展程序得到共计4(Nr+1)字的扩展密钥。它涉及如下三个模块:
    4 G9 k3 @5 k! i" u* Z
    & H  r, v; E- c9 `& i① 位置变换(rotword)——把一个4字节的序列[A,B,C,D]变化成[B,C,D,A];
    ! {1 D8 u6 O! j2 r# z0 U, I8 j; `
    % P3 }9 \3 ^8 h! T8 {% {5 J② S盒变换(subword)——对一个4字节进行S盒代替;( g4 w+ H  n/ y' u2 v& I

    + E( S8 U; K; f0 J& F③ 变换Rcon——Rcon表示32位比特字[xi-1,00,00,00]。, m. D# |8 @# I; N

    7 e, _5 n5 T7 ]) O- K, w6 V% w% W% h这里的x是(02),如 Rcon[1]=[01000000];Rcon[2]=[02000000];Rcon[3]=[04000000]……   
    3 T4 G3 x) t  ~; D$ q" J5 p1 d/ A7 N* N
    扩展密钥的生成:扩展密钥的前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]。6 A/ w% U4 _& `7 `1 @' N

    - V( }% v5 {) u1 V+ h* FAES的加密与解密流程。3 \( H- b  H8 @
    $ X2 O, n( V/ L9 E7 T2 b
    12.jpg
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-9-30 18:38 , Processed in 0.557162 second(s), 59 queries .

    回顶部