×

基于VHDL的AES加密算法的实现

消耗积分:0 | 格式:doc | 大小:12 KB | 2011-04-11

正果

分享资料个

  预处理:构造密钥调度表w[ ]

  Sbox: 一个16*16的矩阵

  (1) w[] 最初的 Nk (6) 行被作为种子,用原始密钥值(0x00 到0x17)。剩余行从种子密钥来产生。变量 Nk 代表以 32 位字为单位的种子密钥长度。如192字节密钥就为6.

  (2) 剩余的w[]是由前面的密钥产生,AES规范称为密钥扩展(KeyExpansion) .在KeyExpansion过程中会用到三个操作:RotWord, SubWord, Rcon(轮常数)

  RotWord: 它接受一个4个字节的数组并将它们向左旋转一个位置。因为轮调度表 w[] 有四列,RotWord 将 w[]的1行左旋

  SubWord: SubWord 例程使用替换表 Sbox 对一给定的一行密钥调度表 w[] 进行逐字节替换。被代替的输入字节被分成 (x,y) 对,它被当作进入替换表 Sbox 的索引。举例来说,0x27的代替结果是 x=2 和 y=7,并且 Sbox[2,7] 返回 0xcc。

  Rcon: KeyExpansion 例程使用一个被称为轮常数表的数组 Rcon[]。这些常数都是4个字节,每一个与密钥调度表的某一行相匹配。AES 的 KeyExpansion 例程需要11个轮常数 每个轮常数的最左边的字节是GF(28)域中2的幂次方

 

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

评论(0)
发评论

下载排行榜

全部0条评论

快来发表一下你的评论吧 !