Python实行任意文件的加密—解密

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: Python实行任意文件的加密—解密

Python实行任意文件的加密—解密
环 境:

系统:macOS Sonoma

IDE:PyCharm 2024 Professional Edition

源代码如下:

from cryptography.fernet import Fernet
import os

# 定义一个加密类
class Encrypt:
    # 参数是需要被加密的文件
    def __init__(self, input_file):
        # 加密的密钥
        self.key = None
        self.input_file = input_file
        # 加密文件的名字
        self.encrypted_file = os.path.basename(input_file).split('.')[0]+'_encrypted.' + os.path.basename(input_file).split('.')[1]

    # 定义一个加密方法
    def encrypt_file(self):
        self.key = Fernet.generate_key()
        cipher_suite = Fernet(self.key)
        if os.path.isfile(input_file) and os.path.exists(input_file):
        # 把加密的密钥保存到指定的文件夹,记住保存好,否则无法解密
            with open(os.path.dirname(input_file) + '/' + os.path.basename(input_file).split('.')[0] + '_key.txt', 'wb') as f:
                f.write(self.key)

            with open(self.input_file, 'rb') as file:
                file_data = file.read()

            encrypted_data = cipher_suite.encrypt(file_data)
            # 生成加密文件
            with open(os.path.dirname(input_file) + '/' + self.encrypted_file, 'wb') as file:
                file.write(encrypted_data)
            print('加密成功!注意保管加密的密钥!!')
            return True
        else:
            print('加密失败!')
            return False

# 定义一个解密的类
class Decrypt:
    # 被加密的文件和加密时生成的密钥作为参数, 需要完整的路径
    def __init__(self, encrypted_file, input_key):
        self.encrypted_file = encrypted_file
        self.decrypted_file_name = os.path.basename(self.encrypted_file).split('.')[0].strip('_encrypted') + os.path.basename(self.encrypted_file).split('.')[1]
        self.key = input_key
        # 需要解密的加密文件的路径
        self.path = os.path.dirname(self.encrypted_file)

    # 定义一个解密方法
    def decrypt_file(self):
        if os.path.isfile(self.encrypted_file) and os.path.exists(self.encrypted_file):
            with open(self.key, 'rb') as f:
                self.key = f.read()
            cipher_suite = Fernet(self.key)

            with open(self.encrypted_file, 'rb') as file:
                encrypted_data = file.read()

            decrypted_data = cipher_suite.decrypt(encrypted_data)
            with open(self.path + '/'+ self.decrypted_file_name + '_decrypted'
                      +
                      '.' + os.path.basename(self.encrypted_file).split('.')[1], 'wb') as file:
                file.write(decrypted_data)
            print('解密成功!')
            return True
        else:
            print('解密失败!')
            return False


if __name__ == '__main__':
      # 输出一个菜单
    print('= ' * 15)
    print('1. 加密'.center(20, ' '))
    print('2. 解密'.center(20, ' '))
    print('= ' * 10)
    choice = input('请输入您的选择:')
    if int(choice) == 1:
        input_file = input('请输入要加密的文件(包括完整路径):')
        encrypt_file = Encrypt(input_file)
        encrypt_file.encrypt_file()

    if int(choice) == 2:
        input_file = input('请输入要解密的文件(包括完整路径):')
        input_key = input('请输入要解密的密钥(包括完整的路径):')
        Decrypt(input_file, input_key).decrypt_file()

运行结果如下图所示:
image.png
image.png
image.png
image.png

⚠️:部分加密的代码由AI生成!感谢这个伟大的AI时代。真是太给力了,大大的提高了工作效率。

相关文章
|
24天前
|
安全 Linux 数据安全/隐私保护
python知识点100篇系列(15)-加密python源代码为pyd文件
【10月更文挑战第5天】为了保护Python源码不被查看,可将其编译成二进制文件(Windows下为.pyd,Linux下为.so)。以Python3.8为例,通过Cython工具,先写好Python代码并加入`# cython: language_level=3`指令,安装easycython库后,使用`easycython *.py`命令编译源文件,最终生成.pyd文件供直接导入使用。
python知识点100篇系列(15)-加密python源代码为pyd文件
|
7天前
|
开发者 Python
Python中__init__.py文件的作用
`__init__.py`文件在Python包管理中扮演着重要角色,通过标识目录为包、初始化包、控制导入行为、支持递归包结构以及定义包的命名空间,`__init__.py`文件为组织和管理Python代码提供了强大支持。理解并正确使用 `__init__.py`文件,可以帮助开发者更好地组织代码,提高代码的可维护性和可读性。
10 2
|
29天前
|
Linux 区块链 Python
Python实用记录(十三):python脚本打包exe文件并运行
这篇文章介绍了如何使用PyInstaller将Python脚本打包成可执行文件(exe),并提供了详细的步骤和注意事项。
48 1
Python实用记录(十三):python脚本打包exe文件并运行
|
23天前
|
Java Python
> python知识点100篇系列(19)-使用python下载文件的几种方式
【10月更文挑战第7天】本文介绍了使用Python下载文件的五种方法,包括使用requests、wget、线程池、urllib3和asyncio模块。每种方法适用于不同的场景,如单文件下载、多文件并发下载等,提供了丰富的选择。
|
23天前
|
数据安全/隐私保护 流计算 开发者
python知识点100篇系列(18)-解析m3u8文件的下载视频
【10月更文挑战第6天】m3u8是苹果公司推出的一种视频播放标准,采用UTF-8编码,主要用于记录视频的网络地址。HLS(Http Live Streaming)是苹果公司提出的一种基于HTTP的流媒体传输协议,通过m3u8索引文件按序访问ts文件,实现音视频播放。本文介绍了如何通过浏览器找到m3u8文件,解析m3u8文件获取ts文件地址,下载ts文件并解密(如有必要),最后使用ffmpeg合并ts文件为mp4文件。
|
29天前
|
JSON 数据格式 Python
Python实用记录(十四):python统计某个单词在TXT/JSON文件中出现的次数
这篇文章介绍了一个Python脚本,用于统计TXT或JSON文件中特定单词的出现次数。它包含两个函数,分别处理文本和JSON文件,并通过命令行参数接收文件路径、目标单词和文件格式。文章还提供了代码逻辑的解释和示例用法。
36 0
Python实用记录(十四):python统计某个单词在TXT/JSON文件中出现的次数
|
1天前
|
SQL 安全 物联网
网络安全与信息安全:深入探讨网络漏洞、加密技术及安全意识###
网络安全与信息安全是当今数字化时代的重要议题。本文将详细探讨网络安全和信息安全的差异,重点介绍常见的网络漏洞、加密技术以及如何提升用户和组织的安全意识。通过具体案例和技术分析,帮助读者理解这些关键概念,并提供实用的建议以应对潜在的网络威胁。 ###
|
2天前
|
安全 网络安全 数据安全/隐私保护
网络安全的盾牌与剑:漏洞、加密与意识
【10月更文挑战第35天】在这个数字化不断深入的时代,网络安全成了保护我们数据和隐私的重要屏障。本文将深入浅出地探讨网络安全中的漏洞发现、加密技术的应用以及提升个人安全意识的重要性,旨在为读者提供一扇了解和防御网络威胁的窗口。从黑客如何利用漏洞发起攻击,到如何使用加密技术保护数据,再到为何培养良好的安全习惯对抵御网络犯罪至关重要,我们将一一解析。让我们携手构建一个更安全的网络环境。
|
3天前
|
SQL 安全 算法
网络安全与信息安全:漏洞、加密与意识的交织
【10月更文挑战第35天】在数字化时代,网络安全不再是可选项,而是每个网民的必修课。本文旨在深入探讨网络安全的核心要素,包括常见的安全漏洞、先进的加密技术以及不可或缺的安全意识。通过分析这些方面,我们将揭示如何保护个人和组织免受网络攻击的策略,同时提供实用的代码示例,以增强读者的实践能力。文章将引导您思考如何在日益复杂的网络环境中保持警惕,并采取积极措施以确保数据的安全。
15 4
|
2天前
|
监控 安全 网络安全
网络安全的盾牌:漏洞防御与加密技术的现代策略
【10月更文挑战第36天】在数字化浪潮中,网络安全成为保护个人隐私和企业资产的关键防线。本文深入探讨网络安全漏洞的成因、影响及防御措施,并分析加密技术如何为信息安全提供坚固保障。通过案例分析和代码示例,揭示提升安全意识的重要性及其在防范网络攻击中的作用,旨在为读者提供一套全面的网络安全解决方案和预防策略。