QQ登录

只需要一步,快速开始

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

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

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

937

主题

117

听众

3万

积分

升级  0%

  • TA的每日心情

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

    [LV.8]以坛为家I

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

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

    群组2013年数学建模国赛备

    AES每一个圈变换由以下三个层组成:/ r: O6 }$ b3 J, I0 l7 i- h
    非线性层——进行Subbyte变换;# \( f5 M  e4 u& Y
    线行混合层——进行ShiftRow和MixColumn运算;% h- F# H3 z) y: F+ b; K
    密钥加层——进行AddRoundKey运算。% j& y2 R* D3 k- [  r8 b4 ]; V
    ① Subbyte变换是作用在状态中每个字节上的一种非线性字节转换,可以通过计算出来的S盒进行映射。
    4 C" j6 z4 F; J# B9 U3 n② ShiftRow是一个字节换位。它将状态中的行按照不同的偏移量进行循环移位,而这个偏移量也是根据Nb的不同而选择的[3]。7 H; J0 `7 L( M5 H' Q
    ③ 在MixColumn变换中,把状态中的每一列看作GF(28)上的多项式a(x)与固定多项式c(x)相乘的结果。 b(x)=c(x)*a(x)的系数这样计算:
    1 R0 O+ X+ b+ Q2 h, \+ t5 x9 q* [7 l3 T- R& f) [
    *运算不是普通的乘法运算,而是特殊的运算,即 b(x)=c(x)·a(x)(mod x4+1) 对于这个运算 b0=02。a0+03。a1+a2+a3 令xtime(a0)=02。a0
    5 @) H6 v6 X$ W. L: J8 O( `1 t* w: e. S' w
    其中,符号“。”表示模一个八次不可约多项式的同余乘法[3]。; f$ k, {; ~/ n+ z# j: }# g& }$ J0 M

    2 |) b4 [7 b) O( c6 \+ @ 11.jpg
    - K# s' N# p  S- G) h
    * a8 ]( f" a) r6 K3 t对于逆变化,其矩阵C要改变成相应的D,即b(x)=d(x)*a(x)。
    & f% k4 I& k+ b5 U+ _④ 密钥加层运算(addround)是将圈密钥状态中的对应字节按位“异或”。; P) M8 ^! \# E0 F- o. b2 d* }
    ⑤ 根据线性变化的性质[1],解密运算是加密变化的逆变化。这里不再详细叙述。+ L' l4 ~! t2 U5 k! v
    二、轮变化   
    & Z% T7 _$ d' f8 @( J) o
    : L8 v: a) r) A% y7 p" i对不同的分组长度,其对应的轮变化次数是不同的,如表1所列。
    % T/ a% M) T( _% p# d% z
    + U1 }( Z% U6 D1 M 1.jpg
    + n5 w: L0 x$ _1 B# a2 m
    ' y1 k* ?8 v/ j5 A8 i三、密钥扩展  
    ) q1 r1 L* }1 g8 {& ?) H2 v7 v4 z+ u
    : ?' x! r1 E2 e$ kAES算法利用外部输入密钥K(密钥串的字数为Nk),通过密钥的扩展程序得到共计4(Nr+1)字的扩展密钥。它涉及如下三个模块:& a. x! Q" ]7 I; B% H

    % h" i* }% y. g. H2 n① 位置变换(rotword)——把一个4字节的序列[A,B,C,D]变化成[B,C,D,A];$ |. X+ X% t1 L$ [6 K' D
    % i& \9 h3 N5 O, b+ h9 I
    ② S盒变换(subword)——对一个4字节进行S盒代替;
    - ^% y7 m6 B" ?
    0 A' h$ @" h0 y( J3 V③ 变换Rcon——Rcon表示32位比特字[xi-1,00,00,00]。
    8 Q: N) U9 H6 I% b5 C" n) {6 w7 l5 o0 F- k4 K3 Z6 @
    这里的x是(02),如 Rcon[1]=[01000000];Rcon[2]=[02000000];Rcon[3]=[04000000]……   
    6 E0 Q6 K4 J1 p$ z; P, k1 I! q# U3 k: a8 I* Y# p9 {( ^
    扩展密钥的生成:扩展密钥的前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]。' y! m# z( ?+ a0 c

    + d% a" E8 Q  Z  GAES的加密与解密流程。8 Z; y  f( n/ k8 r+ `" A6 q( P
    , a+ c2 M; d/ I3 g3 M$ c; W
    12.jpg
    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2026-4-16 20:29 , Processed in 0.467921 second(s), 60 queries .

    回顶部