当前位置: 首页 > ai >正文

【Python练习】053. 编写一个函数,实现简单的文件加密和解密功能

053. 编写一个函数,实现简单的文件加密和解密功能

  • 053. 编写一个函数,实现简单的文件加密和解密功能
    • 安装依赖
    • 文件加密和解密代码
      • 代码说明:
      • 示例运行:
      • 注意事项:
    • 应用场景
    • 加密与解密的区别
    • 实现方法
      • 方法1:使用对称加密(如AES)
      • 方法2:使用非对称加密(如RSA)
    • 选择依据

053. 编写一个函数,实现简单的文件加密和解密功能

以下是一个简单的Python函数,用于实现文件的加密和解密功能。这里使用了对称加密算法(如AES),因为它是实现文件加密的常用方法之一。我们将使用cryptography库来完成这个任务。

安装依赖

首先,确保安装了cryptography库。如果尚未安装,可以通过以下命令安装:

pip install cryptography

文件加密和解密代码

以下代码提供了一个简单的文件加密和解密功能:

from cryptography.hazmat.primitives.ciphers import Cipher, algorithms, modes
from cryptography.hazmat.primitives.kdf.pbkdf2 import PBKDF2HMAC
from cryptography.hazmat.primitives import hashes
from cryptography.hazmat.backends import default_backend
from cryptography.hazmat.primitives import padding
import osdef generate_key(password: str, salt: bytes) -> bytes:"""使用密码和盐值生成密钥:param password: 用户提供的密码:param salt: 盐值:return: 生成的密钥"""kdf = PBKDF2HMAC(algorithm=hashes.SHA256(),length=32,  # AES-256需要32字节的密钥salt=salt,iterations=100000,backend=default_backend())return kdf.derive(password.encode())def encrypt_file(input_file: str, output_file: str, password: str):"""加密文件:param input_file: 输入文件路径:param output_file: 输出文件路径:param password: 加密密码"""# 生成随机盐值salt = os.urandom(16)# 生成密钥key = generate_key(password, salt)# 生成随机IV(初始化向量)iv = os.urandom(16)# 创建AES加密器cipher = Cipher(algorithms.AES(key), modes.CBC(iv), backend=default_backend())encryptor = cipher
http://www.xdnf.cn/news/15846.html

相关文章:

  • Filter快速入门 Java web
  • SaTokenException: 未能获取对应StpLogic 问题解决
  • c#:TCP服务端管理类
  • Spark专栏开篇:它从何而来,为何而生,凭何而强?
  • EPLAN 电气制图(十): 继电器控制回路绘制(下)放料、放灰
  • 机器学习基础:从数据到智能的入门指南
  • 第三章自定义检视面板_创建自定义编辑器类_编辑器操作的撤销与恢复(本章进度3/9)
  • MySQL锁(一) 概述与分类
  • 算法讲解--复写零
  • 旋转位置编码-ROPE简单理解
  • 《剥开洋葱看中间件:Node.js请求处理效率与错误控制的深层逻辑》
  • go-redis Pipeline 与事务
  • 国产电钢琴性价比实战选购指南
  • Selenium 处理动态网页与等待机制详解
  • SpringBoot 整合 Langchain4j 实现会话记忆存储深度解析
  • 面试高频题 力扣 417. 太平洋大西洋水流问题 洪水灌溉(FloodFill) 深度优先遍历(dfs) 暴力搜索 C++解题思路 每日一题
  • 从零到一MCP快速入门实战【1】
  • MySQL锁(二) 共享锁与互斥锁
  • PHPStorm携手ThinkPHP8:开启高效开发之旅
  • 【华为机试】23. 合并 K 个升序链表
  • Leetcode 06 java
  • LeetCode 121. 买卖股票的最佳时机
  • 试用SAP BTP 02:试用SAP HANA Cloud
  • 算法分析--时间复杂度
  • Hadoop小文件合并技术深度解析:HAR文件归档、存储代价与索引结构
  • Function Callingの进化路:源起篇
  • gradle关于dependency-management的使用
  • 【实证分析】会计稳健性指标分析-ACF、CScore、Basu模型(2000-2023年)
  • 贝叶斯分类器的相关理论学习
  • Qwen3-8B 的 TTFT 性能分析:16K 与 32K 输入 Prompt 的推算公式与底层原理详解