Linux Python下实现文件加密与解密

发布时间:2024-09-12 11:26:44 作者:小樊
来源:亿速云 阅读:79

在 Linux 系统中,使用 Python 实现文件加密和解密可以通过多种方法

  1. 安装 PyCryptoDome 库:
pip install pycryptodome
  1. 编写加密和解密的 Python 脚本:
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_filedecrypt_file。它们分别用于加密和解密文件。在主程序中,我们首先生成一个 256 位的随机密钥,然后使用这个密钥加密名为 “input.txt” 的文件,并将加密后的内容保存到 “encrypted.txt” 文件中。接着,我们使用相同的密钥解密 “encrypted.txt” 文件,并将解密后的内容保存到 “decrypted.txt” 文件中。

注意:在实际应用中,请确保密钥的安全存储和传输。不要将密钥直接写入代码或明文传输。

推荐阅读:
  1. 【我的Linux,我做主!】使用Apache服务部署Web论坛网站
  2. 实现Linux数据加密的方法有哪些

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

python

上一篇:Linux Python脚本管理系统服务状态

下一篇:Python Linux环境下Docker容器编排

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》