用verilog实现AES密码算法1---一些理论准备

用verilog实现AES密码算法1—一些理论准备

这两周做了一个课程设计,是AES密码算法的加解密,用verilog实现的,因为从原理到设计花了一些时间,笔记本上记录了一堆厚厚的分析资料,俗话说好记性不如烂笔头,我觉得有必要记录这些工作。

AES算法总体介绍

AES算法的分组长度和密钥长度均能被独立指定为128位、192位或256位,密钥长度不同,则加密轮数不同。本次实验以密钥长度128位,加密10轮为例,算法中16字节的明文、密文和轮密钥都以一个4x4的矩阵表示。下图为AES算法加解密的流程图:
 AES加解密流程图
AES加密过程涉及到4种操作:分别是字节替代(SubBytes)、行移位(ShiftRows)、列混淆(MixColumns)和轮密钥加(AddRoundKey)。解密过程分别为对应的逆操作。由于每一步操作都是可逆的,按照相反的顺序进行解密即可恢复明文。加解密中每轮的密钥分别由初始密钥扩展得到。下面是AES一轮加密的过程。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值