AES加密算法

news2024/11/18 1:45:07

AES算法原理

  1. 对称加密算法(用于取代DES算法,发展历史DES-3DES-AES)
  2. 明文长度固定为128位(DES:64位),密钥长度可128位、192位、256位(DES:64位)

加密原理

最终轮没有列混合运算!

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HlJyNQEK-1675004895822)(AES加密算法.assets/image-20220304212738115.png)]

字节顺序

因为AES明文加密每组为128bit,16byte = 128bit,它的排列方式为如下(字节为单位):

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ufcpZeRU-1675004895824)(AES加密算法.assets/image-20220304213336535.png)]

1. 初始变化

将每组的明文128bit和密钥的128bit进行异或得到一轮初始变换

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-hbD7C7Ji-1675004895827)(AES加密算法.assets/image-20220307121905640.png)]

2. 9轮循环运算

2.1 字节代还

通过上面得到了一个和子密钥异或完的64byte(128bit)数据,然后将每个字节看作一个x,y坐标,到S-BOX表中进行索引值,并填入原来的位置,如图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-88XljAYr-1675004895832)(AES加密算法.assets/image-20220307122535209.png)]

最终替换完成表的数据为如下图:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pwDeWosP-1675004895837)(AES加密算法.assets/image-20220307122623982.png)]

2.2 行移位

同样将数据分为16个字节,以字节为单位进行行移位,第一行不变,第二行向左移动1byte,第三行向左移动2byte,第四行向左移动3byte。例子步骤如图所示:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-S9DLwGoM-1675004895842)(AES加密算法.assets/image-20220307170149307.png)]

2.3 列混合

将拿到的16个字节矩阵进行左乘一个固定的4*4的矩阵(相乘算法看下面列混合相乘章节)。例子步骤如图所示:

比如:第一行:(02,03,01,01) * (d4,bf,5d,30) = (02 * d4) xor (03 * bf) xor 5d xor 30 = 04

第二行:(01,02,03,01) * (e0,b4,52,ae) = e0 xor (02 * b4) xor (03 * 52) xor ae = cb

第三行:(01,01,02,03) * (b8,41,11,f1) = d3

第三行:(03,01,01,02) * (1e,27,98,e5) = 4c

补充:(01,02,03,01) * (e0,b4,52,ae) = 66

在这里插入图片描述

2.4 轮密钥加

将列混合后的数据与经过轮密钥后的子密钥子密钥由来看下面密钥加密章节)进行列对列异或,得到新的数据

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2NM9B57e-1675004895847)(AES加密算法.assets/image-20220307171538657.png)]

3. 最终轮

在经过前面的9轮步骤后,第十次加密时,不采用列混合步骤其他步骤一样,完成最终的明文加密到密文

密钥加密

当密钥为16byte时(128bit)先将该数据进行列分类,例子如图所示:其中i的取值分为2种情况,如下图思维图所示,其中T()表示一个轮函数

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-XLZGzpLR-1675004895855)(AES加密算法.assets/image-20220307173256206.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Pe19fTvE-1675004895858)(AES加密算法.assets/image-20220307174249600.png)]

字循环:将1个字(Word)中4个字节(byte)循环左移1个字节,即[b[0],b[1],b[2],b[3]] -> [b[1],b[2],b[3],b[0]]

字节代换:对字循环的结果使用S盒进行字节代换,S盒如下图1所示

轮常量异或:将字节代换的结果用轮常量Rco[j]进行异或,j表示轮数,轮常量表如图2:

​ 图一:S盒

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-vlwOI073-1675004895862)(AES加密算法.assets/image-20220307180512025.png)]

​ 图二:轮常量表

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-7IiBjlyj-1675004895865)(AES加密算法.assets/image-20220307181322455.png)]

那么T(W[3]) 可计算为[09,cf,4f,3c] -----> [cf,4f,3c,09] ------> [8a,84,eb,01] -------> [8b,84,eb,01]

设i = 4,这里i是4的倍数表示为W[4] = W[0] xor T(W[3]) 其中T由字循环、字节代换、轮常量异或组成。

W[4] = [2b,7e,15,16] xor [8b,84,eb,01] = [a0,fa,fe,17]

设i = 5,那么不是4的倍数则表示为W[5] = W[1] xor W[4]

W[5] = [28,ae,d2,a6] xor [a0,fa,fe,17] = [88,54,2c,b1]

最后经过10轮加密后的密钥为如图所示:每一轮的密钥对应每一轮的明文加密(比如我在第一轮加密就使用Round key 1依此类推)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-rCfhX6mp-1675004895871)(AES加密算法.assets/image-20220307182218212.png)]

列混合相乘

在一个数(记为a)与2相乘时:

​ 先转换为二进制->(00000010) * (a7 a6 a5 a4 a3 a2 a1 a0) 当a7为0时算术左移一位-> (a7 a6 a5 a4 a3 a2 a1 a0 0) ,当a7不为0时 (a7 a6 a5 a4 a3 a2 a1 a0 0) xor (00011011)

在一个数(记为a)与3相乘时:

​ 先转换为二进制->(00000011) * (a7 a6 a5 a4 a3 a2 a1 a0) = (00000010 xor 00000001) * (a7 a6 a5 a4 a3 a2 a1 a0) = (00000010 * (a7 a6 a5 a4 a3 a2 a1 a0)) xor (a7 a6 a5 a4 a3 a2 a1 a0) ####可理解为a乘以2再加上一个a

在一个数(记为a)与4相乘时:

​ 先转换为二进制->(00000100) * (a7 a6 a5 a4 a3 a2 a1 a0) = 00000010* 00000010 * (a7 a6 a5 a4 a3 a2 a1 a0)

例题1:求 2 * 0xd4
= 00000010 * 11010100 #这里的a7为1
= 10101000 xor 00011011 #那么就是0xd4算术左移一位,取异或值
= 10110011
例题2: 求 3 * 0xbf
= (00000011 * 10111111)
= (00000010 * 10111111) xor 10111111  #这里的a7为1
= (01111110 xor 00011011 ) xor 10111111 
= 11011010

例题3: (02 * b4) xor (03 * 52)
= (00000010 * 10110100) xor (00000011 * 01010010)
= (01101000 xor 00011011) xor ((00000010 * 01010010) xor 01010010)
= (01101000 xor 00011011) xor (10100100 xor 01010010)
= 10000101
byte x=0x3,byte y=0x63 求x*y
= (00000011 * 01100011)
= (00000010 * 01100011) xor  01100011
= 11000110 xor 01100011
= 0xa5

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/186001.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

你是如何对待植物神经紊乱的?

大家好,你们是如何对待植物神经紊乱这种疾病的? 你们知道吗?植物神经紊乱是一种情绪情志障碍伴躯体化症状的特殊且复杂的疾病,这种疾病可能会导致浑身的不适。 并且,很多植物神经紊乱的患者发现,这种疾病是…

【GD32F427开发板试用】硬件SPI通信驱动CH376芯片,用单片机实现U盘数据下载

本篇文章来自极术社区与兆易创新组织的GD32F427开发板评测活动,更多开发板试用活动请关注极术社区网站。作者:周文杰 SPI通信作为单片机多种基础数据传输模式中的一种,驱动外部芯片CH376实现数据导出到U盘功能在实际工程项目中是很方便的。本…

字符设备驱动之mmap、select

一、mmap mmap,简而言之就是将内核空间的一段内存区域映射到用户空间。映射成功后,用户对这段内存区域的修改可以直接反映到内核空间,相反,内核空间对这段区域的修改也直接反映用户空间。那么对于内核空间与用户空间两者之…

Prometheus + Grafana + Alertmanager 本地安装调试

一、简介 Prometheus 是一款强大的监控软件,一般会与Grafana和Alertmanager一起配合使用,而且多用于k8s集群。简介的话网上很多,官网 更是详细,这里就不班门弄斧了。k8s集群环境下的安装网上很多,但是k8s集群搭建时间…

【实际开发10】- 远程调用 ( Feign )

目录 1. Feign 调用注意事项 - ★★★ 1. 【原则】: 禁止遍历 - 多次跨服务调用接口 ( 提需求 : idList ) 1. 单一数据查询 , 可直接用 Feign单一查询接口 2. List数据查询 , 需进行 Feign 数据转换 , 禁止遍历 Feign 3. stream() : 从List<对象> , 取出 id 和 name…

关于PS VR2和独占,开发者和分析师都怎么看

近期&#xff0c;索尼正式宣布了PS VR2首发游戏列表&#xff0c;共计37款游戏&#xff0c;其中包括备受关注的IP大作《地平线&#xff1a;山之召唤》等。从这37款首发阵容中可以看到一个现象&#xff0c;大部分游戏是非新作&#xff0c;而是已经在PS VR1或其它VR平台上线&#…

C++基础——C++数组

C基础——C数组C 数组声明数组初始化数组访问数组元素C 中数组详解C 数组 C 支持数组数据结构&#xff0c;它可以存储一个固定大小的相同类型元素的顺序集合。数组是用来存储一系列数据&#xff0c;但它往往被认为是一系列相同类型的变量。 数组的声明并不是声明一个个单独的…

【数据结构基础】线性表 - 链表

n个节点离散分配&#xff0c;彼此通过指针相连&#xff0c;每个节点只有一个前驱节点&#xff0c;每个节点只有一个后续节点&#xff0c;首节点没有前驱节点&#xff0c;尾节点没有后续节点。确定一个链表我们只需要头指针&#xff0c;通过头指针就可以把整个链表都能推出来。知…

设计模式-UML图

目录 2&#xff0c;UML图 2.1 类图概述 2.2 类图的作用 2.3 类图表示法 2.3.1 类的表示方式 2.3.2 类与类之间关系的表示方式 2&#xff0c;UML图 统一建模语言&#xff08;Unified Modeling Language&#xff0c;UML&#xff09;是用来设计软件的可视化建模语言。它的特…

Matlab pdetool

云溪岩绵迎彩霞,博主精神压力大呀,没人说说知心话啊,SCU物理要命啦........基本物理方程静电磁场交流电磁场热传导Options->ApplicationGeneric Scalar泛型标量Generic System通用系统Structural Mechanics,Plane Stress结构力学 - 平面应力Structural Mechanics,Plane Stra…

Flashback Oracle文档阅读

和Flashback相关的文档大多位于备份和恢复用户指南 和Oracle 数据库开发指南中。 基本概念 请参看备份和恢复用户指南的1.4 About Oracle Flashback Technology。 Oracle Flashback Technology的定义&#xff1a; A set of Oracle Database features that provide an additi…

Verilog HDL门级建模

⭐本专栏针对FPGA进行入门学习&#xff0c;从数电中常见的逻辑代数讲起&#xff0c;结合Verilog HDL语言学习与仿真&#xff0c;主要对组合逻辑电路与时序逻辑电路进行分析与设计&#xff0c;对状态机FSM进行剖析与建模。 &#x1f525;文章和代码已归档至【Github仓库&#xf…

数字电路设计:Logicly 最新版Crack

Logicly有效地教授逻辑门 数字电路 — 使用 Logicly 现代直观的用户界面支持拖放、复制/粘贴、缩放等功能&#xff0c;可快速轻松地设计电路。 通过暂停模拟并在您逐步推进时观察信号传播来控制调试。 不用担心学生计算机上的多个平台。在 Windows 和 macOS 上安装 创建引人入…

子查询-MySQL

文章目录理解举例基本使用语法分类分类方式1单行子查询多行子查询分类方式2&#xff1a;单行子查询单行比较操作符代码示例HAVING 中的子查询CASE中的子查询子查询中的空值问题非法使用子查询多行子查询多行比较操作符代码示例相关子查询相关子查询执行流程代码示例EXISTS 与 N…

USART学习笔记

目录 1. USART框图 2. 传输帧图 3. 配置步骤 4.配置编码&#xff08;使用库函数&#xff09; 5. 函数调用缩略图 1. USART框图 2. 传输帧图 起始位的特征&#xff1a;时钟引脚CK处于低电平&#xff0c;TX引脚处于低电平&#xff0c;持续1个SCLK长度&#xff08;位长度&…

2020-ICLR-Memory-Based Graph Networks

2020-ICLR-Memory-Based Graph Networks Paper&#xff1a;https://arxiv.org/abs/2002.09518 Code: https://github.com/amirkhas/GraphMemoryNet 基于内存的图网络 图神经网络&#xff08;GNN&#xff09;是一类可对任意拓扑结构的数据进行操作的深度模型。 作者为GNN引入了…

Python类调用实例方法

通常情况下&#xff0c;我们习惯使用类对象调用类中的实例方法。但如果想用类调用实例方法&#xff0c;不能像如下这样&#xff1a;class CLanguage: definfo(self): print("我正在学 Python") #通过类名直接调用实例方法 CLanguage.info()运行上面代码&#xff0c;程…

线路板行业含铜废水处理,铜箔废水深度处理和铜回收

产品介绍 传统沉淀法不能满足日益提的环保要求(如电镀表三镍含量要求0.1mg/l以下)。针对特定重金属离子的特点&#xff0c;利用螯合树脂的特种功能基团与重金属离子形成络合物的特性&#xff0c;实现重金属离子的回收利用及深度去除。 CH-90Na对除铜镍铅锌钴锰等具有特定的选择…

GBASE亮相第四代英特尔® 至强® 可扩展处理器新品发布

1月11日&#xff0c;英特尔&#xff08;中国&#xff09;有限公司成功举办“芯加速 行至远”——第四代英特尔发布会。GBASE南大通用作为英特尔的长期战略合作伙伴&#xff0c;双方联合推出GBase 8a大规模分布式并行处理&#xff08;MPP&#xff09;数据库集群系统解决方案&…

在spring boot3中使用native image

文章目录简介安装GraalVM添加Native Image支持构建spring boot3应用总结简介 在之前spring boot3文章中我们介绍了&#xff0c;spring boot3的一个重要特性就是支持把spring boot3的应用编译成为GraalVM的Native Image。 今天我们用具体的例子来给大家演示一下如何正确的将sp…