AES与DES加密解密算法_aes 文件 解密,2024年最新大专生三面蚂蚁金服

S盒变换是按字节进行的代替变换,是作用在状态中每个字节上的一种非线性字节变换。首先将字节的值用它的乘法逆来代替,然后将获取的值按照下面的式子进行仿射变换。

2.行位移变换

行移位变换对状态行进行循环移位。在行移位变换中,状态的后三行以不同的移位值循环左移。第0行不移位,第1行向左移动C1字节,第2行向左移动C2字节,第3行向左移动C3字节,移位表如下

NbC1C2C3
4123
6123
8134

3.列混合变换

列混合变换是对状态的列进行混合变换,把状态中的每一列看做GF(28)上的多项式,并与一个固定多项式c(x)相乘,然后与多项式x4+1进行取模运算,其中c(x)可表示为:

c(x)='03'x3+'01'x2+'01'x+'02'

4.圈密钥加变换

圈密钥加变换是利用圈密钥对状态进行模2相加的变换。圈密钥被简单地异或到状态中去。其中,圈密钥长度等于数据块长度。

综上所述,AES加密算法由三部分组成:初始圈密钥加、Nr-l圈的标准轮函数、最后一圈的非标准轮函数。

四、Python编写AES加密解密算法

接下来将通过Cryptodome库函数实现对字符串进行AES加密。由于AES为分组密码的加密方式,其工作模式有五种:ECB、CBC、CTR、CFB、OFB。Windows系统中安装pycryptodomex库

1.加密

from Cryptodome.Cipher import AES
import binascii

key = b’abcdefghabcdefgh’ # key的长度须为8字节
text = ‘python.com’ # 被加密的数据需要为8字节的倍数
text = text + (16 - (len(text) % 16)) * ‘=’
aes = AES.new(key, AES.MODE_ECB) # ECB模式
encrypto_text = aes.encrypt(text.encode())
encryptResult = binascii.b2a_hex(encrypto_text)
print(text)
print(encryptResult)

2.解密算法

from Cryptodome.Cipher import AES
import binascii

key = b’abcdefghabcdefgh’ # key的长度须为8字节
encryptResult = b’1a24bd3880741675ec7978d277e26262’ # 解密字符串
aes = AES.new(key, AES.MODE_ECB) # ECB模式
encrypto_text = binascii.a2b_hex(encryptResult)
decryptResult = aes.decrypt(encrypto_text)
print(decryptResult)

五、DES简介

早先,为了满足对计算机数据安全性越来越高的需求,美国国家标准局(NBS)于1973年征用了IBM公司提交的一种加密算法,并经过一段时间的试用和征求意见,于1977年1月5日颁布,作为数据加密标准(Data Encryption Standard,DES),其设计目的是用于加密保护静态存储和传输信道中的数据。DES算法为密码体制中的对称密码体制,又称为美国数据加密标准。

六、DES加密原理

DES加密算法综合运用了置换、代替、代数等多种密码技术,具有设计精巧、实现容易、使用方便等特点。DES加密算法的明文、密文和密钥的分组长度都是64位。

1.DES密钥产生过程

64位密钥经子密钥产生算法产生16个48位子密钥。 64位明文首先经过初始置换IP(Initial Pennutation),将数据打乱重新排列,并分成左右两边,各32位序列。 加密函数f实现子密钥K1对K0的加密,结果为32位的数据组f(R0,K1)。f(R0,K1)再与L0的模2相加,又得到一个32位的数组L0⊕f(R0,K1),以L0⊕f(R0,K1)作为第二次加密迭代的R1,以R0作为第二次加密迭代的Ll,第二次加密迭代至第十六次加密迭代分别用子密钥K2,…,K16进行,其过程与第一次加密迭代相同。 第16次加密迭代结束后,产生一个64位的数据组。以其左边32位作为R16,右边32位作为L16,两者合并后经过逆初始置换IP-1将数据重新排列,便得到64位密文。至此,加密结束。

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数网络安全工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加VX:vip204888 (备注网络安全获取)
img

学习路线:

这个方向初期比较容易入门一些,掌握一些基本技术,拿起各种现成的工具就可以开黑了。不过,要想从脚本小子变成黑客大神,这个方向越往后,需要学习和掌握的东西就会越来越多以下是网络渗透需要学习的内容:
在这里插入图片描述

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-zaUqQvvf-1712645326706)]

  • 14
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用 OpenSSL 库实现对称加密解密算法 DESAES 的步骤如下: 1. 引入 OpenSSL 库头文件和链接库: ```c #include <openssl/des.h> #include <openssl/aes.h> // 链接库需要添加 -lcrypto 参数 ``` 2. 生成密钥: ```c DES_cblock key_des; DES_random_key(&key_des); ``` ```c unsigned char key_aes[AES_BLOCK_SIZE]; RAND_bytes(key_aes, AES_BLOCK_SIZE); ``` 3. 初始化加密解密上下文: ```c DES_key_schedule schedule; DES_set_key(&key_des, &schedule); ``` ```c AES_KEY key_aes; AES_set_encrypt_key(key_aes, 128, &key_aes); AES_set_decrypt_key(key_aes, 128, &key_aes); ``` 4. 加密解密数据: ```c DES_encrypt1(input, output, &schedule); DES_decrypt1(input, output, &schedule); ``` ```c AES_encrypt(input, output, &key_aes); AES_decrypt(input, output, &key_aes); ``` 完整的示例代码如下所示: ```c #include <openssl/des.h> #include <openssl/aes.h> #include <openssl/rand.h> #include <stdio.h> #include <string.h> int main() { // DES加密解密 DES_cblock key_des; DES_random_key(&key_des); unsigned char input_des[] = "Hello, world!"; unsigned char output_des[32]; DES_key_schedule schedule; DES_set_key(&key_des, &schedule); DES_encrypt1(input_des, output_des, &schedule); DES_decrypt1(output_des, input_des, &schedule); printf("DES decrypted message: %s\n", input_des); // AES加密解密 unsigned char key_aes[AES_BLOCK_SIZE]; RAND_bytes(key_aes, AES_BLOCK_SIZE); unsigned char input_aes[] = "Hello, world!"; unsigned char output_aes[32]; AES_KEY aes_key; AES_set_encrypt_key(key_aes, 128, &aes_key); AES_encrypt(input_aes, output_aes, &aes_key); AES_set_decrypt_key(key_aes, 128, &aes_key); AES_decrypt(output_aes, input_aes, &aes_key); printf("AES decrypted message: %s\n", input_aes); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值