您好,登錄后才能下訂單哦!
在 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進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。