python 如何实现 aes 加密?

这篇具有很好参考价值的文章主要介绍了python 如何实现 aes 加密?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在Python中,使用pycryptodome库可以轻松地实现AES加密。本文将介绍如何使用Python实现AES加密以及如何使用pycryptodome库来进行加密。

什么是AES加密?


AES(Advanced Encryption Standard)是一种对称密钥加密算法,被广泛用于保护数据的安全。它是目前最常用的加密算法之一,被广泛应用于数据通信、数据存储和计算机安全领域。

在AES加密中,加密和解密使用相同的密钥。它支持128位、192位和256位密钥长度,并可以使用不同的加密模式(如ECB、CBC、CFB、OFB等)进行加密。在加密过程中,明文被划分为若干个块,然后每个块使用密钥进行加密,最终生成密文。在解密时,密文被解密成明文块,并使用相同的密钥进行还原。

如何使用Python实现AES加密?


Python是一种高级编程语言,广泛应用于数据科学、机器学习、人工智能等领域。使用Python实现AES加密非常容易,只需要安装pycryptodome库即可。

以下是一个简单的AES加密示例:

from Crypto.Cipher import AES
import base64

# 需要加密的明文
plain_text = "Hello World!"

# 密钥,长度必须是16、24或32字节
key = "This is a key123".encode()

# 加密模式,可以是CBC、CFB、ECB、OFB等模式
mode = AES.MODE_CBC

# 填充字符
padding = b" "

# 创建一个AES对象
cipher = AES.new(key, mode)

# 对明文进行填充
pad_len = AES.block_size - len(plain_text) % AES.block_size
padding_str = padding * pad_len
plain_text = plain_text.encode() + padding_str

# 加密
cipher_text = cipher.encrypt(plain_text)

# 使用Base64编码转换成字符串
cipher_text_str = base64.b64encode(cipher_text).decode()

print(cipher_text_str)

以上代码中,key表示密钥,长度必须是16、24或32字节;mode表示加密模式,可以是CBC、CFB、ECB、OFB等模式;padding表示填充字符,通常使用空格。

plain_text是需要加密的明文,首先需要进行填充,然后使用AES.new()方法创建一个AES对象。接着调用encrypt()方法进行加密,最后使用base64模块将加密结果转换成字符串。

需要注意的是,在使用CBC模式时,需要指定一个初始化向量(IV),可以使用Random.new().read(AES.block_size)来生成一个随机的IV。在解密时,需要使用相同的密钥和IV才能还原明文本,以下是一个使用CBC模式和随机IV的AES加密示例:

from Crypto.Cipher import AES
from Crypto import Random
import base64

# 需要加密的明文
plain_text = "Hello World!"

# 密钥,长度必须是16、24或32字节
key = "This is a key123".encode()

# 加密模式,使用CBC模式
mode = AES.MODE_CBC

# 填充字符
padding = b" "

# 随机生成IV
iv = Random.new().read(AES.block_size)

# 创建一个AES对象
cipher = AES.new(key, mode, iv)

# 对明文进行填充
pad_len = AES.block_size - len(plain_text) % AES.block_size
padding_str = padding * pad_len
plain_text = plain_text.encode() + padding_str

# 加密
cipher_text = cipher.encrypt(plain_text)

# 将IV和密文拼接成一个字节串
cipher_text_bytes = iv + cipher_text

# 使用Base64编码转换成字符串
cipher_text_str = base64.b64encode(cipher_text_bytes).decode()

print(cipher_text_str)


在以上代码中,使用Random.new().read(AES.block_size)方法生成一个随机的IV,然后在创建AES对象时将其传入。在加密时,将生成的IV和密文拼接成一个字节串。在解密时,需要先将密文解码为字节串,然后将字节串的前16个字节作为IV,剩余的字节作为加密后的数据进行解密。

如何使用pycryptodome库实现AES加密?


pycryptodome是一个Python密码学库,是pycrypto库的加强版。它提供了多种加密算法和加密模式的实现,包括AES、RSA、DSA、DH等算法。

以下是一个使用pycryptodome库实现AES加密的示例:

from Crypto.Cipher import AES
from Crypto.Util.Padding import pad
import base64

# 需要加密的明文
plain_text = "Hello World!"

# 密钥,长度必须是16、24或32字节
key = "This is a key123".encode()

# 加密模式,使用CBC模式
mode = AES.MODE_CBC

# 填充字符
padding = b" "

# 随机生成IV
iv = Random.new().read(AES.block_size)

# 创建一个AES对象
cipher = AES.new(key, mode, iv)

# 对明文进行填充
plain_text = pad(plain_text.encode(), AES.block_size, style='pkcs7')

# 加密
cipher_text = cipher.encrypt(plain_text)

# 将IV和密文拼接成一个字节串
cipher_text_bytes = iv + cipher_text

# 使用Base64编码转换成字符串
cipher_text_str = base64.b64encode(cipher_text_bytes).decode()

print(cipher_text_str)


与前面的示例不同,这里使用了Crypto.Util.Padding模块中的pad()方法对明文进行填充,使用pkcs7填充模式,这样可以保证加密和解密时都能够正确处理填充。

如何使用cryptography库实现AES加密?


cryptography是一个现代化的Python密码学库,提供了一种更安全、更易用的API。它支持的加密算法包括AES、RSA、DSA、ECC等。

以下是一个使用cryptography库实现AES加密的示例:

from cryptography.fernet import Fernet

# 需要加密的明文
plain_text = "Hello World!"

# 密钥,长度必须是32字节
key = b"This is a key123456789012345678901234567890"

# 创建一个Fernet对象
cipher = Fernet(key)

# 加密
cipher_text = cipher.encrypt(plain_text.encode())

# 解密
plain_text = cipher.decrypt(cipher_text).decode()

print(cipher_text)
print(plain_text)


在以上示例中,首先需要生成一个32字节的密钥。然后,创建一个Fernet对象,使用密钥对明文进行加密,得到密文。解密时,使用相同的密钥对密文进行解密,得到明文。

与前面两个示例不同,cryptography库并没有提供AES加密的直接接口,而是使用了更高层次的封装。这种封装方式可以简化加密操作,但可能会影响加密的灵活性。


本文介绍了三种常用的Python库实现AES加密的方法,分别是pycrypto、pycryptodome和cryptography。这些库提供了不同层次的API,使用者可以根据实际需求选择适合自己的库。
 文章来源地址https://www.toymoban.com/news/detail-734013.html

到了这里,关于python 如何实现 aes 加密?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Python 基于pycryptodome,实现对AES、DES、3DES、RSA等常用加密算法的使用,文末附各种加密的源码示例

    (中文名:加密圆顶)pycryptodome是一个基于c实现的Python库,它在2.x中支持2.7以上版本,或3.x中支持3.5以上版本的Python。 可以使用以下命令安装它: 该库支持以下特性 认证加密模式 Authenticated encryption modes (GCM, CCM, EAX, SIV, OCB) AES加密在英特尔上的加速 Accelerated AES on Intel platf

    2023年04月09日
    浏览(75)
  • go语言使用AES加密解密

    Go语言提供了标准库中的crypto/aes包来支持AES加密和解密。下面是使用AES-128-CBC模式加密和解密的示例代码:

    2024年02月06日
    浏览(42)
  • go语言对称加密使用(DES、3DES、AES)

    进行DES、3DES、AES三种对称加密算法时,首先要对原始数据进行字节填充,使原始数据位数与所对应加密算法块数据量成倍数。 block cipher(分组密码、块密码) block size(块大小) DEA、3DES的block size为8位 AES的block size为16位 每个填充的字节都记录了填充的总字节数 \\\"a\\\" 填充后:

    2024年02月08日
    浏览(34)
  • Python使用CBC加密模式进行AES加密

    在这个示例中,我们使用了 cryptography 库的 Cipher、algorithms、modes、backend 和 padding 模块。 encrypt 函数接受明文字符串、密钥和初始向量(IV)作为参数。 我们首先使用 Cipher 类来创建一个 AES 密码器对象,指定所需的 AES 算法、CBC 加密模式和密钥。然后,我们获取密码器的加密

    2024年01月24日
    浏览(34)
  • Python学习笔记——AES 加密/解密

    AES,高级加密标准。目前比较流行的对称加密算法。是一种对称加密算法,即加密和解密都用相同的密钥。 AES只是个基本算法,实现AES有几种模式,主要有ECB、CBC、CFB等几种模式。CBC模式中还有一个偏移量参数IV。 AES加密有AES-128、AES-192和AES-256三种,分别对应三种密钥长

    2023年04月15日
    浏览(33)
  • 【Python】AES 128加密和解密

    AES加密标准又称为高级加密标准Rijndael加密法,是美国国家标准技术研究所NIST旨在取代DES的21世纪的加密标准。AES的基本要求是,采用对称分组密码体制,密钥长度可以为128、192或256位,分组长度128位,算法应易在各种硬件和软件上实现。1998年NIST开始AES第一轮分析、测试和征

    2024年02月13日
    浏览(41)
  • AES对称加密实战——前端js加密后端python解密

    高级加密标准(AES, Advanced Encryption Standard),是一种最常见的对称加密算法 。其加密流程如下图所示,发送方通过密钥对明文加密后进行网络传输,接收方用同样的密钥将密文解密。在前后端通讯场景中,可利用AES算法对用户密码进行加密后传输,防止被抓包而造成密码泄露。

    2024年02月04日
    浏览(42)
  • RSA+AES实现混合加密

    为什么使用RSA + AES混合加密 1.加密介绍 RSA加密: 属于非对称加密,公钥用于对数据进行加密,私钥对数据进行解密,两者不可逆。公钥和私钥是同时生成的,且一一对应。比如:客户端拥有公钥,服务端拥有公钥和私钥。客户端将数据通过公钥进行加密后,发送密文给服务端

    2024年02月05日
    浏览(37)
  • S-AES加密实现

    S-AES是AES的简化版本,其只使用了16位的明文和16位的密钥进行加密。以下介绍S-AES的加密步骤。 测试数据:使用密钥 1010 0111 0011 1011 加密二进制明文 0110 1111 0110 1011 ,得出二进制密文 0000 0111 0011 1000 。 简化版的AES和原本AES的步骤差不多,只是在轮数和一些运算的字节数上有不

    2023年04月08日
    浏览(24)
  • Python对AES进行加密和解密的多种方法

    前言 本文是该专栏的第24篇,后面会持续分享python的各种干货知识,值得关注。 做过爬虫项目的同学,对AES加解密都有遇到过。 在密码学中,加密算法也分为双向加密和单向加密。单向加密包括MD5、SHA等摘要算法,它们是不可逆的。而双向加密包括 对称加密 和 非对称加密

    2023年04月14日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包