当前位置:
首页 > Python基础教程 >
-
Python pycryptodome库实现RSA加密解密消息
使用Python的`pycryptodome`库实现RSA加密和解密消息是一个相对直接的过程。以下是一个完整的例子,展示了如何生成RSA密钥对、加密和解密一个消息。
首先,确保你已经安装了`pycryptodome`库。如果没有,你可以通过pip安装它:
接下来,是生成RSA密钥对、加密和解密消息的完整代码示例:
在这个例子中,我们首先导入了必要的模块和类。`RSA`类用于生成和操作RSA密钥,而`PKCS1_OAEP`类用于加密和解密消息,这是RSA加密的一种常见填充模式,提供了更好的安全性。
我们定义了三个函数:
- `generate_rsa_keypair`:生成RSA密钥对,并返回私钥和公钥的字符串表示。
- `encrypt_message`:接受公钥和消息作为输入,返回加密后的消息(字节串)。
- `decrypt_message`:接受私钥和加密后的消息作为输入,返回解密后的原始消息(字符串)。
在主程序中,我们生成了一个RSA密钥对,加密了一个简单的消息,然后解密了该消息,并打印了原始消息、加密后的消息(以十六进制形式显示)和解密后的消息。
请注意,由于加密后的消息是字节串,所以在打印时我们使用了`.hex()`方法将其转换为十六进制字符串以便阅读。然而,在实际应用中,你通常会以字节串的形式存储或传输加密后的消息。
最后,如果你对python语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/Python/python50252.html
首先,确保你已经安装了`pycryptodome`库。如果没有,你可以通过pip安装它:
pip install pycryptodome
接下来,是生成RSA密钥对、加密和解密消息的完整代码示例:
from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_OAEP
import os
# 生成RSA密钥对
def generate_rsa_keypair():
key = RSA.generate(2048) # 生成2048位的密钥
private_key = key.export_key()
public_key = key.publickey().export_key()
return private_key, public_key
# 使用公钥加密消息
def encrypt_message(public_key, message):
recipient_key = RSA.import_key(public_key)
cipher_rsa = PKCS1_OAEP.new(recipient_key)
encrypted_msg = cipher_rsa.encrypt(message.encode('utf-8'))
return encrypted_msg
# 使用私钥解密消息
def decrypt_message(private_key, encrypted_msg):
private_key = RSA.import_key(private_key)
cipher_rsa = PKCS1_OAEP.new(private_key)
decrypted_msg = cipher_rsa.decrypt(encrypted_msg)
return decrypted_msg.decode('utf-8')
# 主程序
if __name__ == "__main__":
# 生成RSA密钥对
private_key, public_key = generate_rsa_keypair()
# 要加密的消息
message = "Hello, RSA Encryption!"
print(f"原始消息: {message}")
# 加密消息
encrypted_message = encrypt_message(public_key, message)
print(f"加密后的消息(十六进制): {encrypted_message.hex()}")
# 解密消息
decrypted_message = decrypt_message(private_key, encrypted_message)
print(f"解密后的消息: {decrypted_message}")
from Crypto.Cipher import PKCS1_OAEP
import os
# 生成RSA密钥对
def generate_rsa_keypair():
key = RSA.generate(2048) # 生成2048位的密钥
private_key = key.export_key()
public_key = key.publickey().export_key()
return private_key, public_key
# 使用公钥加密消息
def encrypt_message(public_key, message):
recipient_key = RSA.import_key(public_key)
cipher_rsa = PKCS1_OAEP.new(recipient_key)
encrypted_msg = cipher_rsa.encrypt(message.encode('utf-8'))
return encrypted_msg
# 使用私钥解密消息
def decrypt_message(private_key, encrypted_msg):
private_key = RSA.import_key(private_key)
cipher_rsa = PKCS1_OAEP.new(private_key)
decrypted_msg = cipher_rsa.decrypt(encrypted_msg)
return decrypted_msg.decode('utf-8')
# 主程序
if __name__ == "__main__":
# 生成RSA密钥对
private_key, public_key = generate_rsa_keypair()
# 要加密的消息
message = "Hello, RSA Encryption!"
print(f"原始消息: {message}")
# 加密消息
encrypted_message = encrypt_message(public_key, message)
print(f"加密后的消息(十六进制): {encrypted_message.hex()}")
# 解密消息
decrypted_message = decrypt_message(private_key, encrypted_message)
print(f"解密后的消息: {decrypted_message}")
在这个例子中,我们首先导入了必要的模块和类。`RSA`类用于生成和操作RSA密钥,而`PKCS1_OAEP`类用于加密和解密消息,这是RSA加密的一种常见填充模式,提供了更好的安全性。
我们定义了三个函数:
- `generate_rsa_keypair`:生成RSA密钥对,并返回私钥和公钥的字符串表示。
- `encrypt_message`:接受公钥和消息作为输入,返回加密后的消息(字节串)。
- `decrypt_message`:接受私钥和加密后的消息作为输入,返回解密后的原始消息(字符串)。
在主程序中,我们生成了一个RSA密钥对,加密了一个简单的消息,然后解密了该消息,并打印了原始消息、加密后的消息(以十六进制形式显示)和解密后的消息。
请注意,由于加密后的消息是字节串,所以在打印时我们使用了`.hex()`方法将其转换为十六进制字符串以便阅读。然而,在实际应用中,你通常会以字节串的形式存储或传输加密后的消息。
最后,如果你对python语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/Python/python50252.html
栏目列表
最新更新
求1000阶乘的结果末尾有多少个0
详解MyBatis延迟加载是如何实现的
IDEA 控制台中文乱码4种解决方案
SpringBoot中版本兼容性处理的实现示例
Spring的IOC解决程序耦合的实现
详解Spring多数据源如何切换
Java报错:UnsupportedOperationException in Col
使用Spring Batch实现批处理任务的详细教程
java中怎么将多个音频文件拼接合成一个
SpringBoot整合ES多个精确值查询 terms功能实
SQL Server 中的数据类型隐式转换问题
SQL Server中T-SQL 数据类型转换详解
sqlserver 数据类型转换小实验
SQL Server数据类型转换方法
SQL Server 2017无法连接到服务器的问题解决
SQLServer地址搜索性能优化
Sql Server查询性能优化之不可小觑的书签查
SQL Server数据库的高性能优化经验总结
SQL SERVER性能优化综述(很好的总结,不要错
开启SQLSERVER数据库缓存依赖优化网站性能
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比