在 Linux 系统中,使用 Python 实现文件加密和解密可以通过多种方法
pip install pycryptodome
from Crypto.Cipher import AES
from Crypto.Random import get_random_bytes
from Crypto.Util.Padding import pad, unpad
import base64
# 加密函数
def encrypt_file(key, input_filename, output_filename):
cipher = AES.new(key, AES.MODE_CBC)
with open(input_filename, 'rb') as infile:
data = infile.read()
padded_data = pad(data, AES.block_size)
encrypted_data = cipher.encrypt(padded_data)
with open(output_filename, 'wb') as outfile:
outfile.write(base64.b64encode(cipher.iv + encrypted_data))
# 解密函数
def decrypt_file(key, input_filename, output_filename):
with open(input_filename, 'rb') as infile:
data = base64.b64decode(infile.read())
iv = data[:AES.block_size]
cipher = AES.new(key, AES.MODE_CBC, iv)
decrypted_data = unpad(cipher.decrypt(data[AES.block_size:]), AES.block_size)
with open(output_filename, 'wb') as outfile:
outfile.write(decrypted_data)
if __name__ == "__main__":
key = get_random_bytes(32) # 生成一个 256 位的随机密钥
# 加密文件
encrypt_file(key, "input.txt", "encrypted.txt")
# 解密文件
decrypt_file(key, "encrypted.txt", "decrypted.txt")
这个脚本定义了两个函数:encrypt_file
和 decrypt_file
。它们分别用于加密和解密文件。在主程序中,我们首先生成一个 256 位的随机密钥,然后使用这个密钥加密名为 “input.txt” 的文件,并将加密后的内容保存到 “encrypted.txt” 文件中。接着,我们使用相同的密钥解密 “encrypted.txt” 文件,并将解密后的内容保存到 “decrypted.txt” 文件中。
注意:在实际应用中,请确保密钥的安全存储和传输。不要将密钥直接写入代码或明文传输。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。