使用python加密主机文件几种方法实现

news2024/11/25 16:42:19

本文主要介绍了使用python加密主机文件几种方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

数据加密是一种保护数据安全的技术,通过对数据进行编码,使得未经授权的用户无法读取或改动数据。

加密是通过使用加密算法和密钥实现的。加密算法是一种特定的算法,可以将数据编码成不可读的形式,密钥是一串字符串,用于控制加密和解密的过程。加密后的数据只能使用对应的密钥解密。

加密在保护数据的安全性方面非常重要,尤其是在互联网和移动设备环境中,用户的隐私数据容易遭到黑客的攻击。加密技术不仅可以保护数据的隐私,还可以保护数据的完整性,确保数据不被篡改。

在企业环境中,数据加密也被广泛应用于保护公司数据的安全。从合同到秘密文件,加密技术可以保护公司数据不被未经授权的人员查看。

总的来说,数据加密是一种重要的保护数据安全的技术,对于任何用户和企业都非常重要。

要求:利用python对某个目录的全部文件进行加密,密钥由用户的输入的字符串经过变化而生成,封装为一个函数,输入参数有目录路径和用户输入的字符串。

以下是使用 Python 实现的一种简单的文件加密方案:

1

2

3

4

5

6

7

8

9

10

11

12

13

importos

importhashlib

defencrypt_directory(directory, password):

forroot, dirs, files inos.walk(directory):

forfileinfiles:

path =os.path.join(root, file)

with open(path, 'rb') as f:

data =f.read()

key =hashlib.sha256(password.encode()).hexdigest()

encrypted_data =bytearray(x ^ ord(key[i %len(key)]) fori, x inenumerate(data))

with open(path, 'wb') as f:

f.write(encrypted_data)

该函数接收两个参数:目录路径和用户输入的字符串。它通过使用 os.walk 对目录下的每个文件进行加密,并将加密后的数据写回文件。加密使用了异或操作,密钥是对用户输入的字符串进行 SHA-256 哈希的十六进制字符串。

以下是对上面的加密函数的对应解密函数:

1

2

3

4

5

6

7

8

9

10

11

scssCopy code

defdecrypt_directory(directory, password):

forroot, dirs, files inos.walk(directory):

forfileinfiles:

path =os.path.join(root, file)

with open(path, 'rb') as f:

encrypted_data =f.read()

key =hashlib.sha256(password.encode()).hexdigest()

data =bytearray(x ^ ord(key[i %len(key)]) fori, x inenumerate(encrypted_data))

with open(path, 'wb') as f:

f.write(data)

该函数与上面的加密函数类似,但是它读入加密后的文件,并使用相同的密钥对数据进行异或操作,以获得原始文件。

将上述代码更换加密算法,使用AES加密,代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

importos

importhashlib

fromCrypto.Cipher importAES

defencrypt_directory(directory, password):

# 计算密钥

key =hashlib.sha256(password.encode()).digest()[:16]

forroot, dirs, files inos.walk(directory):

forfileinfiles:

path =os.path.join(root, file)

# 读取文件

with open(path, 'rb') as f:

data =f.read()

# 对数据进行补位

padding_length =16-len(data) %16

data +=bytes([padding_length] *padding_length)

# 初始化加密器

cipher =AES.new(key, AES.MODE_ECB)

# 加密数据

encrypted_data =cipher.encrypt(data)

# 将加密后的数据写回文件

with open(path, 'wb') as f:

f.write(encrypted_data)

defdecrypt_directory(directory, password):

# 计算密钥

key =hashlib.sha256(password.encode()).digest()[:16]

forroot, dirs, files inos.walk(directory):

forfileinfiles:

path =os.path.join(root, file)

# 读取文件

with open(path, 'rb') as f:

encrypted_data =f.read()

# 初始化解密器

cipher =AES.new(key, AES.MODE_ECB)

# 解密数据

data =cipher.decrypt(encrypted_data)

# 删除补位数据

padding_length =data[-1]

data =data[:-padding_length]

# 将解密后的数据写回文件

with open(path, 'wb') as f:

f.write(data)

注:上面的代码仅供参考,不建议在生产环境中使用。AES ECB 模式并不是很安全,应该使用其他模式。

或者使用非对称加密:

这里使用RSA加密算法实现数据的加密解密:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

importos

importrsa

defencrypt_file(file_path, public_key_file):

"""使用RSA算法加密文件

参数:

file_path: 需要加密的文件路径

public_key_file: 公钥文件路径

返回值:

"""

# 读取文件内容

with open(file_path, "rb") as file:

file_content =file.read()

# 读取公钥

with open(public_key_file, "rb") as key_file:

public_key =rsa.PublicKey.load_pkcs1(key_file.read())

# 加密文件内容

encrypted_content =rsa.encrypt(file_content, public_key)

# 将加密后的内容写入文件

with open(file_path, "wb") as file:

file.write(encrypted_content)

defdecrypt_file(file_path, private_key_file, password):

"""使用RSA算法解密文件

参数:

file_path: 需要解密的文件路径

private_key_file: 私钥文件路径

password: 私钥文件密码

返回值:

"""

# 读取文件内容

with open(file_path, "rb") as file:

encrypted_content =file.read()

# 读取私钥

with open(private_key_file, "rb") as key_file:

private_key =rsa.PrivateKey.load_pkcs1(key_file.read(), password)

# 解密文件内容

file_content =rsa.decrypt(encrypted_content, private_key)

# 将解密后的内容写入文件

with open(file_path, "wb") as file:

file.write(file_content)

需要注意的是,RSA加密的效率较低,适用于加密少量数据,如对文件进行加密

到此这篇关于使用python加密主机文件几种方法实现的文章就介绍到这了。

300+Python经典编程案例
50G+学习视频教程
点击拿去

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/336640.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

你所不知道的Number()、parseInt()、parseFloat()转换细则

为什么要写这篇文章 最近在阅读《javascript高级程序设计》(第6版)这本书,以写代记。同时刚刚入职新公司,发现自己对于number类型转换的细节掌握不足 使用场景 我们常常对于很多字符串类型的数字需要转换成Number,一…

2023春节,蔚来高速免费换电累计达37万余次

2023年春节放假前,蔚来官方宣布高速换电免费消息: 在高速公路上(含高速出入口)的所有蔚来汽车换电站将为蔚来用户,提供不限次免费换电服务。 消息发布后,部分电动车企也进行了跟进,提供了特定区…

二十四、Gtk4-GtkExpression

GtkExpression是一种基本类型。它不是GObject的后代。GtkExpression提供了一种描述对值的引用的方法。GtkExpression需要求值才能获得值。 它类似于算术计算。 1 2 3 12是一个表达式。给出了计算的方法。3是来自表达式的值。求值是计算表达式并得到值。 GtkExpression是一种…

【大厂高频真题100题】《有效的井字游戏》 真题练习第26题 持续更新~

有效的井字游戏 给你一个字符串数组 board 表示井字游戏的棋盘。当且仅当在井字游戏过程中,棋盘有可能达到 board 所显示的状态时,才返回 true 。 井字游戏的棋盘是一个 3 x 3 数组,由字符 ,X 和 O 组成。字符 代表一个空位。 以下是井字游戏的规则: 玩家轮流将字符…

CODESYS开发教程10-文件读写(SysFile库)

今天继续我们的小白教程,老鸟就不要在这浪费时间了😊。 前面一期我们介绍了CODESYS的文件操作库CAA File。这一期主要介绍CODESYS的SysFile库所包含的文件读写功能块,主要包括文件路径、名称、大小的获取以及文件的创建、打开、读、写、拷贝…

mysql数据库安装

三种安装方式 tar -xf mysql-5.7.37-linux-glibc2.12-x86_64.tar.gz [rootsc-mysql opt]# tar -xf mysql-5.7.37-linux-glibc2.12-x86_64.tar.gz [rootsc-mysql opt]# ls apache-zookeeper-3.6.3-bin kafka_2.12-2.8.1.tgz apache-zookeeper-3.6.3-bin.tar.gz mysql…

无线局域网

无线局域网(Wireless Local Ara Network,WLAN) 一、无线局域网的组成 无线局域网可分为两大类:(1)有基础设施的;(2)无基础设施的。 1. IEEE802.11 对于有基础设施的无…

Spring boot 实战指南(三):整合Elasticsearch、swagger、redis、mq

文章目录一、Elasticsearch创建项目配置maven完善依赖es连接配置实体映射repositoryservicecontroller二、swagger依赖启动类路径匹配配置配置类controller注解三、redis一、Elasticsearch 官方文档 Elasticsearch教程 自己搭建了一个简单的demo,仓库在这里&#…

分布式之CAP理论分析

写在前面 任何存在的事物都有其内在的特性,分布式也不例外,那么分布式都有什么特性呢?国外有大牛就帮我们总结了如下的三点: C:Consitency,一致性 A:Available,可用性 P:Partition tolerance&…

细讲一个 TCP 连接能发多少个 HTTP 请求(二)

第三个问题:一个 TCP 连接中 HTTP 请求发送可以一起发送么(比如一起发三个请求,再三个响应一起接收)? HTTP/1.1 存在一个问题,单个 TCP 连接在同一时刻只能处理一个请求,意思是说:两…

测试员都是背锅侠?测试人员避“锅”攻略,拿走不谢

最近发生了一起生产事故,究其根源,事故本身属于架构或者需求层面需要规避的问题,测试人员的责任其实是非常小的,但实际情况是:相关测试人员因此承担了很大的压力,成为质量问题的“背锅侠”。 实际上&#…

极验2代验证码分析

目标链接 aHR0cDovL3d3dy5qc2dzai5nb3YuY246NTg4ODgvbWluaS9uZXR3ZWIvU01MaWJyYXJ5LmpzcA接口分析 点击搜索就会跳出验证码,netWebServlet.json 的请求,会返回 challenge 和 gt 接着可以看响应请求图片信息的接口,可以看到请求参数包含cha…

iOS 组件化或SDK时对资源加载注意点

本文针对cocoapods进行打包的资源做个讲解,针对自身项目注意调整资源访问策略。 资源文件打包方式 使用pod lib create AppResourceModule 来进行演示。 use_frameworks! target AppResourceModule_Example dopod AppResourceModule, :path > ../ end podfil…

Python+Flask+MySQL开发的在线外卖订餐系统(附源码)

文章目录一、项目模块及功能介绍1、登录模块2、注册模块3、商家用户模块4、买家用户模块5、系统管理员模块源码二、项目结构三、环境依赖四、运行方法五、系统部分界面展示1、首页2、注册界面3、登录界面4、商家主界面5、商家菜单界面6、商家添加菜品界面7、商家修改菜品界面8、…

数值程序分析

原文来自微信公众号“编程语言Lab”:数值程序分析 搜索关注“编程语言Lab”公众号(HW-PLLab)获取编程语言更多技术内容! 欢迎加入编程语言社区 SIG-程序分析,了解更多程序分析相关的技术内容。 加入方式:添…

实现自动化部署前端项目,从安装Jenkins到部署完成的整体配置 --适合初学Jenkins、想实现或者学习自动化部署的同学,知识点比较全面,过程写的清晰

前言 一、什么是Jenkins 二、Jenkins安装配置 Linux环境安装JDK Linux环境安装Maven Linux安装Jenkins 启动Jenkins jenkins配置 配置汉化版的jenkins 安装gitHub插件 gitHub配置 jenkins的配置 jenkins的gitHub配置 jenkins的java环境配置 小总结 两种情况 第…

RPCMon:一款基于ETW的RPC监控工具

关于RPCMon RPCMon是一款基于事件跟踪的WindowsRPC监控工具,该工具是一款GUI工具,可以帮助广大研究人员通过ETW(Event Tracing for Windows)扫描RPC通信。 RPCMon能够为广大研究人员提供进程之间RPC通信的高级视图,该…

谋变2023:家电巨头进击的“三大关口”

2022年的中国家电行业,无疑在艰难中前行。奥维云网(AVC)推总数据显示,2022年中国家电市场(不含3C)零售额为7081亿元,同比下滑7.4%。下滑背后的推力是多样的,包括地产市场下行、消费者…

服务端返回内容跨域CORS之后,也在chrome/edge浏览器里显示出响应信息

由于浏览器的同源策略,服务端返回的内容跨域,且没有允许跨域CORS的请求头之后,浏览器无法显示出服务端返回的信息,不方便问题排查。比如:Access to XMLHttpRequest at http://localhost:6001/service-app/query/common…

springcloud-工程创建(IDEA)

文章目录介绍springcloud 常用组件1.创建父工程2.删除父工程的src目录3.修改父工程的pom文件4 springcloud 版本依赖5.创建子模块6 子项目下创建启动类介绍 Spring Cloud 是一个基于 Spring Boot 实现的云应用开发工具,它为开发中的配置管理、服务发现、断路器、智…