python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > python pycryptodom加密库

python库pycryptodom加密技术探索(公钥加密私钥加密)

作者:小寒聊python

这篇文章主要为大家介绍了python库pycryptodom加密技术探索(公钥加密私钥加密),有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

python pycryptodome库

今天给大家分享一个超强的 python 库,pycryptodome

https://github.com/Legrandin/pycryptodome       

pycryptodome 是一个在 Python 中用于加密的库,它提供了一系列加密技术,包括对称加密、非对称加密、散列算法和消息认证码等。这个库是 pycrypto 的一个分支,但它解决了 pycrypto 中的一些安全问题和缺陷,并且增加了新的功能和算法支持。pycryptodome 可以作为 pycrypto 的直接替代品,因为它兼容 pycrypto 的API,同时提供了更为丰富和安全的功能。

初体验

下面,我们来介绍一下如何在 Python 中使用 RSA 公钥加密技术来加密和解密消息,并使用 pycryptodome 库进行实现。

RSA算法是一种非对称加密算法,广泛应用于数据传输加密和数字签名等领域。其名称来自于三位发明者 Ron Rivest、Adi Shamir和Leonard Adleman 的首字母。RSA算法在1977年被提出,是最早的公开密钥加密和数字签名算法之一。

库的安装

可以直接通过 pip 来进行安装。

pip install pycryptodome 

生成RSA密钥对

在此示例中,我们将使用 2048 位密钥。

from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_OAEP
from binascii import hexlify

#生成新的 RSA 密钥
key = RSA.generate(2048)
# 使用private_key变量保存生成的密钥
private_key = key
public_key = key.publickey()

使用公钥加密数据

在此示例中,我们将对消息“你好,这是一条要加密的消息”进行加密。

# 使用公钥加密
data_to_encrypt = "你好,这是一条要加密的消息".encode('utf8')
cipher_rsa = PKCS1_OAEP.new(public_key)
encrypted = cipher_rsa.encrypt(data_to_encrypt)

# 使用 hexlify 将二进制数据转换为十六进制以进行显示
print("Encrypted:", hexlify(encrypted))

使用私钥解密数据

# 使用私钥对象进行解密
cipher_rsa = PKCS1_OAEP.new(private_key)
decrypted = cipher_rsa.decrypt(encrypted)

# 将解密结果显示为 UTF-8 编码字符串
print("Decrypted:", decrypted.decode("utf-8"))

以上就是python库pycryptodom加密技术探索(公钥加密私钥加密)的详细内容,更多关于python pycryptodom加密库的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文