这与加密或解密文本完全相同。
示例
首先导入一些模块:
from Crypto.Cipher import AES
from Crypto import Random
key = Random.new().read(AES.block_size)
iv = Random.new().read(AES.block_size)
加密
以下代码加载一个输入文件input.jpg
并对其进行加密,然后将加密数据保存在encrypted.enc
文件中。在此示例中,使用AES块密码和CFB操作模式。
input_file = open("input.jpg")
input_data = input_file.read()
input_file.close()
cfb_cipher = AES.new(key, AES.MODE_CFB, iv)
enc_data = cfb_cipher.encrypt(input_data)
enc_file = open("encrypted.enc", "w")
enc_file.write(enc_data)
enc_file.close()
解密
最后,以下代码加载加密文件encrypted.enc
并对其进行解密,之后将解密数据保存到文件output.jpg
中。
enc_file2 = open("encrypted.enc")
enc_data2 = enc_file2.read()
enc_file2.close()
cfb_decipher = AES.new(key, AES.MODE_CFB, iv)
plain_data = cfb_decipher.decrypt(enc_data2)
output_file = open("output.jpg", "w")
output_file.write(plain_data)
output_file.close()
注意
为了简化,加密和解密在同一Python会话中进行,因此变量key
和iv
被立即重复使用,要测试此解决方案,您需要在同一Python会话中进行加密和解密。当然,如果您想稍后在单独的会话中解密,您需要保存key
和iv
,并在需要解密时重新加载它们。
测试解决方案
现在,您可以打开output.jpg
文件,您应该看到与input.jpg
中相同的图像。
input.jpg
吗?你使用的是哪个Python版本(2还是3)?你的机器上安装了PyCrypto吗? - Kubuntuer82output.jpg
而不是 encrypted.enc
... 文件 output.jpg
是未加密的,仅用于测试加密的正确性,它应该能够打开并且与 input.jpg
完全相同(我也使用了 diff
工具进行了测试)。文件 encrypted.enc
无法打开,因为它已经被加密,所以如果您将其视为输出文件,则预计它无法打开。 - Kubuntuer82