Python RSA 加密解密

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表示使用默认的加密填充方式。

最后,我们将加密后的密文和解密后的明文输出。

你可能感兴趣的:(Python,python)