`
enefry
  • 浏览: 36679 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

AES 加密解密

 
阅读更多

  高级加密标准(Advanced Encryption Standard,AES)

 

 

一、DES 与 AES 比较:

1、DES 采用 56位有效密钥,AES 采用 多种 密钥长度

2、DES 对 64位分组数据进行加密,AES对 128位分组数据进行加密

3、不同于 DES ,AES 不是采用 Feistel 结构,而是置换-组合结构

4、DES 中大量的位操作在软件实现方面不是非常方便,而AES 采用了字节操作。

 

二、图示 AES 加密过程:

 

 

对不同长度的密钥,AES采用不同的加密轮次:

128位 192位 256位
 10 12 14

 

加密过程下面有个视频,我觉得讲得很详细。

三、某些细节:

 ①: 密钥扩展:简单说就是将原来的密钥扩展到足够用的长度。

                       128位密钥: 扩展到 44字(176字节)

                       192位密钥: 扩展到 13*4 = 52 字

                       256位密钥: 扩展到 15*4 = 60 字

        扩展过程请参考代码(不贴出来)和视频。 fun_KeyExpansion()

 

②: 轮密钥加:只是将 数据块和 该轮的密钥进行异或运算 。

 

③:字节替换:有个S盒可以进行替换。(相对于 DES 的替换 ,感觉这个函数的实现是小儿科 )

比如现在有一个字节为: 0x19 (16进制!) 则替换为 0xd4

    

 

 

 

④: 行移位:分成 4 行 第一行不用移位,第二循环左移 8 位 (一个字节 !) 第三行循环移2个字节,第四行移3个字节。

 

 

⑤: 列混淆:这里采用了  上的乘法 。

#define GF_01(b) ((byte)b)
#define GF_02(b) ((byte)((b < 0x80)? ((b<<1)) : (((b<<1) ^ 0x1b))))
#define GF_03(b) ((byte)(((GF_02(b)))^ (( b))))

这几个宏定义,定义了几个运算 而计算过程参考下图和 线性代数知识。


 

 

 

解密过程调用函数不同,理解了加密解密只是一个逆过程。

 

 

四、实现过程的一些解释:

①:首先数据在内存中存放方式:


 ②:行移位的时候采用按字操作,需要注意字有大小端之分:使用宏定义<Little_Endian> 进行控制


 

 

  • 大小: 58.3 KB
  • 大小: 889 Bytes
  • 大小: 4.9 KB
  • 大小: 51.9 KB
  • 大小: 10.8 KB
0
0
分享到:
评论

相关推荐

    Qt实现AES加密解密

    这个程序应当包含了上述知识点的具体应用,你可以通过阅读源代码、编译和运行来进一步理解和学习AES加密解密的实现细节。这个实战例程可以帮助开发者更好地掌握Qt环境下的加密解密操作,提高数据安全保护能力。

    AES加密解密实验报告

    《AES加密解密实验报告》 AES,全称为高级加密标准(Advanced Encryption Standard),是密码学领域中的一个重要标准,由美国联邦政府采纳,用于替换原有的DES加密算法。AES由比利时密码学家Joan Daemen和Vincent ...

    用C语言实现的AES加密解密算法

    在本项目中,"用C语言实现的AES加密解密算法"是针对AES算法的一种C语言实现,这允许开发者在不依赖特定库的情况下,在C环境中进行数据的加密和解密操作。 首先,我们需要理解AES的工作原理。AES的核心是基于替换和...

    AES加密解密算法 iOS和Android完美实现

    在iOS和Android平台上实现AES加密解密是开发者经常遇到的任务,尤其对于需要跨平台传输和存储敏感信息的场景。本篇文章将详细探讨AES加密解密算法在iOS和Android平台上的实现原理以及具体步骤。 首先,AES算法基于...

    C#实现AES加密解密算法

    ### C# 实现 AES 加密解密算法 #### 概述 在计算机科学与信息安全领域,数据加密技术是一项至关重要的技术。AES(Advanced Encryption Standard,高级加密标准)是一种广泛使用的对称加密算法,用于保护敏感数据的...

    本地图片AES加密解密

    "本地图片AES加密解密"是一个针对这个问题提出的技术方案,旨在保护存储在本地设备上的图片不被未经授权的第三方访问。AES(Advanced Encryption Standard)加密是一种广泛应用的对称加密算法,因其高效和安全性而...

    php+uni-app AES加密解密.rar

    在uni-app中,可以使用JavaScript的crypto-js库来实现AES加密解密。首先,你需要通过HBuilderX引入该库,然后在uni-app代码中使用: ```javascript const CryptoJS = require('crypto-js'); const key = 'your_...

    uniapp 前后端AES加密解密.rar

    本压缩包"uniapp 前后端AES加密解密.rar"正是为了解决这一问题,它包含了在uniapp环境下实现前后端AES加密解密的方法。AES(Advanced Encryption Standard),即高级加密标准,是一种广泛使用的对称加密算法,具有...

    AES加密解密 for vba

    ' 功能: AES加密解密 password&lt;==&gt;hwWpiegaWDeE8kTlb/5BQg== , 8705a989e81a583784f244e56ffe4142 ' [Str] 预备转换的byte ' [StrKey] 16位的密钥 ' [StrIv] 16位的偏移 ' [Encrypt] 加密(缺省值)还是解密 ' ...

    C语言实现的AES加密解密

    标题 "C语言实现的AES加密解密" 涉及到的是高级加密标准(Advanced Encryption Standard,简称AES),这是一种广泛使用的对称加密算法,用于保护数据的安全性。AES由NIST(美国国家标准与技术研究所)在2001年标准化...

    C#写的大文件AES加密解密程序

    本项目"大文件AES加密解密程序"就是针对这一需求而设计的,适用于VS2019开发环境,可能无法在较低版本的Visual Studio中正常运行。 AES,全称为Advanced Encryption Standard,是一种广泛使用的对称加密算法,以其...

    VB.NET实现AES加密解密

    VB.NET实现AES加密解密代码,可直接使用

    python实现AES加密解密

    本文实例为大家分享了python实现AES加密解密的具体代码,供大家参考,具体内容如下 (1)对于AES加密解密相关知识 (2)实现的功能就是输入0-16个字符,然后经过AES的加密解密最后可以得到原先的输入,运行的结果...

    c/c++与java互通 AES加密解密

    "C/C++与Java互通AES加密解密"的主题就是这两个议题的结合。AES(Advanced Encryption Standard),即高级加密标准,是一种广泛使用的对称加密算法,提供了强效的数据保护。本话题主要探讨如何在C/C++和Java之间使用...

    C# AES加密解密小工具

    本项目“C# AES加密解密小工具”提供了一个简单的AES ECB模式加密和解密实现,适用于对文本文件进行安全处理。 首先,AES是一种块密码,它将明文分成128位的块进行操作。ECB(Electronic Codebook)模式是最基础的...

    AES加密解密算法转换工具,最大支持256bit长度的密钥.rar

    AES加密解密轮转算法工具,最大支持256bit长度的密钥,明文支持HEX和字串。可供学习设计参考。

    C语言实现AES加密解密

    在C语言中实现AES加密解密是一项基础且重要的技能,特别是在嵌入式系统和低级别编程中。 AES的核心是一个名为Rijndael的密码,由比利时密码学家Joan Daemen和Vincent Rijmen设计。它的工作原理基于一系列的替换和...

    AES加密解密验证工具(支持各种加密模式).exe

    AES加密解密验证工具(支持各种加密模式)

    VB6 AES加密解密文本串和文件的DLL动态库

    本篇文章将详细介绍如何在VB6环境中使用AES加密解密文本串和文件的DLL动态库。 首先,AES是一种块密码,它以128位的数据块为单位进行操作。AES支持三种不同的密钥长度:128位、192位和256位,其中128位是最常见的...

    MFC实现的AES加密解密程序

    **AES加密解密程序概述** AES(Advanced Encryption Standard),即高级加密标准,是目前广泛使用的对称加密算法,因其高效性和安全性而备受青睐。MFC(Microsoft Foundation Classes)是微软提供的一套C++库,用于...

Global site tag (gtag.js) - Google Analytics