RSA算法是一种非对称加密算法,可以用于数据的加密和解密。在Python中,我们可以使用Crypto库来实现RSA加密和解密。
要在Python中使用Crypto库进行加密和解密操作,需要先安装Crypto库。
使用pip安装
在命令行中执行以下命令即可使用pip安装Crypto库:
pip install pycrypto
下面是一个简单的RSA加密和解密的示例代码:
from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5
# 生成RSA密钥对
key = RSA.generate(2048)
# 获取公钥和私钥
public_key = key.publickey()
private_key = key
# 加密字符串
message = 'Hello, world!'
cipher = PKCS1_v1_5.new(public_key)
ciphertext = cipher.encrypt(message.encode())
# 解密字符串
cipher = PKCS1_v1_5.new(private_key)
plaintext = cipher.decrypt(ciphertext, None).decode()
print('加密后的字符串:', ciphertext.hex())
print('解密后的字符串:', plaintext)
代码中,我们首先使用RSA.generate()
函数生成一个RSA密钥对,其中1024
指定了密钥长度。然后,我们使用key.publickey()
获取公钥,key
获取私钥。
接着,我们使用公钥对字符串进行加密,使用私钥对密文进行解密。在加密时,我们使用PKCS1_v1_5.new()
函数创建一个RSA加密器对象,调用encrypt()
函数对字符串进行加密。在解密时,我们同样使用PKCS1_v1_5.new()
函数创建一个RSA解密器对象,调用decrypt()
函数对密文进行解密,其中第二个参数传入None
表示使用默认的加密填充方式。
最后,我们将加密后的密文和解密后的明文输出。