QQ登录

只需要一步,快速开始

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

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

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

937

主题

117

听众

3万

积分

升级  0%

  • TA的每日心情

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

    [LV.8]以坛为家I

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

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

    群组2013年数学建模国赛备

    AES每一个圈变换由以下三个层组成:7 [1 _6 d. I9 S6 a- {
    非线性层——进行Subbyte变换;; u1 Y* J2 a! T, L& f5 N7 p3 K
    线行混合层——进行ShiftRow和MixColumn运算;. {1 h# m0 E/ j0 e' `' q9 g: o! X
    密钥加层——进行AddRoundKey运算。8 t% e; i( ?7 `, `9 Z- G
    ① Subbyte变换是作用在状态中每个字节上的一种非线性字节转换,可以通过计算出来的S盒进行映射。! B1 L4 L' l9 A8 Y0 O5 `
    ② ShiftRow是一个字节换位。它将状态中的行按照不同的偏移量进行循环移位,而这个偏移量也是根据Nb的不同而选择的[3]。
    / h* G0 s" D4 k/ m③ 在MixColumn变换中,把状态中的每一列看作GF(28)上的多项式a(x)与固定多项式c(x)相乘的结果。 b(x)=c(x)*a(x)的系数这样计算:
    - [; S' R5 s- b' B
    - Y) @- z9 j+ W- W7 F! a: F*运算不是普通的乘法运算,而是特殊的运算,即 b(x)=c(x)·a(x)(mod x4+1) 对于这个运算 b0=02。a0+03。a1+a2+a3 令xtime(a0)=02。a08 `% V6 g5 J* a5 t6 I
    9 R. N- t$ {& _
    其中,符号“。”表示模一个八次不可约多项式的同余乘法[3]。0 Z4 x% D5 N8 \0 B

    7 L9 f+ M* |7 O, V 11.jpg
    : S$ E0 J$ Z9 }3 |' R
    1 A( i  n  W3 B% W$ o$ y! z对于逆变化,其矩阵C要改变成相应的D,即b(x)=d(x)*a(x)。" Y7 f( `# P' Z- g: ]% }
    ④ 密钥加层运算(addround)是将圈密钥状态中的对应字节按位“异或”。* i, x: p- w! R" E3 c8 B' y( \
    ⑤ 根据线性变化的性质[1],解密运算是加密变化的逆变化。这里不再详细叙述。% _$ v0 C8 ^$ a2 X. s; o: V' p, S
    二、轮变化   ( S/ ~4 u$ {1 n+ z$ S. F) o

    ) L6 r' k$ N8 r5 c/ @! K对不同的分组长度,其对应的轮变化次数是不同的,如表1所列。9 A1 V/ |4 e, v

    , b$ C) w) m& g# K1 Q7 A$ b 1.jpg 3 g7 J1 g! a* ]/ n* g' X+ N) s
    . E6 o4 q$ O1 I
    三、密钥扩展  % D( X. v9 ?0 U) Z. o- \0 w

    + p' u4 f; m+ |; _1 y: B- uAES算法利用外部输入密钥K(密钥串的字数为Nk),通过密钥的扩展程序得到共计4(Nr+1)字的扩展密钥。它涉及如下三个模块:- \3 W4 L/ M! L6 w& i

    1 D9 ~8 ^. V9 V% j+ }* V① 位置变换(rotword)——把一个4字节的序列[A,B,C,D]变化成[B,C,D,A];5 ?' o% s* h' o4 R# B9 |
    ; C0 G8 H# J5 W/ q* U, x% o
    ② S盒变换(subword)——对一个4字节进行S盒代替;& w! z; q3 p: S3 D! q
    8 M2 Y+ ]: t7 V! g. T+ m
    ③ 变换Rcon——Rcon表示32位比特字[xi-1,00,00,00]。
    8 ?* V5 o9 w8 }2 l
    6 |4 ]6 [- t; R1 i# c' G这里的x是(02),如 Rcon[1]=[01000000];Rcon[2]=[02000000];Rcon[3]=[04000000]……   
    & p0 ^3 Q6 _2 r$ |. a1 O7 k4 |
    / ]1 a, u7 I4 b8 Y- k  w9 M扩展密钥的生成:扩展密钥的前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]。
    + U& V& p) j! P. c. o4 H4 T
    1 z$ y; l% |# }2 fAES的加密与解密流程。
    : l; Z/ ?3 D" G# g
    # i7 y' Z: X6 r7 ~; g9 n, a, u/ w 12.jpg
    回复

    使用道具 举报

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

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

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

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

    蒙公网安备 15010502000194号

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

    GMT+8, 2026-6-15 12:51 , Processed in 0.412317 second(s), 60 queries .

    回顶部