当前位置: 首页 > news >正文

【密码学复习】第四讲分组密码(三)

AES算法的整体结构

AES算法的轮函数

1)字节代换(SubByte)

2)行移位(ShiftRow)

3)列混合(MixColumn)

4)密钥加(AddRoundKey

1-字节代换(ByteSub)

2-行移位(ShiftRow)

3-列混合(MixColumn)

有限域上的字节运算

4—密钥加(AddRoundKey)

AES的

密钥编排由密钥扩展和轮密钥选取两部分组成,其基本原则如下:

1)轮密钥的总比特数等于轮数加1再乘以分组长度;如128比特的明文经过10轮的加密,则总共需要(10+1)*128=1408比特的密钥.

2)种子密钥被扩展成为扩展密钥;

3)轮密钥从扩展密钥中取,其中第1轮轮密钥取扩展密钥的前Nb个字,第2轮轮密钥取接下来的Nb 个字,依次类推.

1)扩展密钥

扩展密钥是以4字节字为元素的一维阵列,表示为W[Nb* (Nr +1)],其中前Nk个字取为种子密钥,以后每个字按递归方式定义.扩展算法根据Nk≤6和Nk >6有所不同。

2) 轮密钥选取

轮密钥i(即第i 个轮密钥)由轮密钥缓冲字W[Nb* i]到W[Nb*(i+1)]给出:

AES 的解密变换AES解密运算是加密运算的逆运算,其中轮函数的逆为:1)ByteSub的逆变换由代换表的逆表做字节代换,也可通过如下两步实现: 首先进行仿射变换的逆变换,再求每一字节在GF(28 )上逆元.

2)行移位运算的逆变换是循环右移,位移量与左移时相同.

3)列混合运算的逆运算是类似的,即每列都用一个特定的多项式d(x)相乘, d(x)满足

(03x3 +01x2 +01x+02)*d(x)=01

由此可得

d(x)=0Bx3 +0Dx2 +09x+0E

4)密钥加运算的逆运算是其自身

http://www.lryc.cn/news/43020.html

相关文章:

  • JVM(内存划分,类加载,垃圾回收)
  • 工作中遇到的问题 -- 你见过哪些写的特别好的代码
  • 基于chatGPT设计卷积神经网络
  • java.sql.Date和java.util.Date的区别
  • 动态规划---线性dp和区间dp
  • 常见的2D与3D碰撞检测算法
  • STM32 10个工程篇:1.IAP远程升级(二)
  • Unity+ChatGpt的联动 AICommand
  • STM-32:按键控制LED灯 程序详解
  • 北邮22信通:(8)实验1 题目五:大整数加减法(搬运官方代码)
  • Fiddler抓取https史上最强教程
  • STM32开发基础知识入门
  • 学习操作系统的必备教科书《操作系统:原理与实现》| 文末赠书4本
  • 大数据的常用算法(分类、回归分析、聚类、关联规则、神经网络方法、web数据挖掘)
  • 【数据结构】详解二叉树与堆与堆排序的关系
  • 【Pandas】数据分析入门
  • 【c++】:list模拟实现“任意位置插入删除我最强ƪ(˘⌣˘)ʃ“
  • QT表格控件实例(Table Widget 、Table View)
  • 第二章Vue组件化编程
  • 面试官:vue2和vue3的区别有哪些
  • 【TopK问题】——用堆实现
  • 【Spring从成神到升仙系列 四】从源码分析 Spring 事务的来龙去脉
  • 使用Nginx反向代理OpenAI API
  • USB键盘实现——字符串描述符(四)
  • STM32的中断
  • Flink进阶篇-CDC 原理、实践和优化采集到Doris中
  • 看完这篇 教你玩转渗透测试靶机vulnhub——My File Server: 1
  • OpenHarmony实战STM32MP157开发板 “控制” Hi3861开发板 -- 中篇
  • 【数据结构初阶】单链表
  • 多线程代码案例-阻塞队列