使用python加密主机文件几种方法实现
本文主要介绍了使用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+学习视频教程
点击拿去
使用python加密主机文件几种方法实现相关推荐
- python遍历数组的两种方法及将print的内容写入文件中
python遍历数组的两种方法 第一种,最常用的,通过for in遍历数组 colours = ["red","green","blue"] ...
- 基础必备 | Python处理文件系统的10种方法
作者 | Jeff Hale 译者 | 风车云马:责编 | Jane,Rachel 出品 | Python大本营(ID:pythonnews) [导读]在编写一些Python程序的时候,我们常常需要与 ...
- 测试Python下载图片的三种方法
简 介: 通过Python软件包对网络URL图片链接进行下载,可以加快后期处理.本文测试了urllib, request两个软件包对图片进行下载效果.如果图片原网页有了防止下载机制,是无法下载图片. ...
- 怎么在python下载网站内容-Python下载网页的几种方法
get和post方式总结 get方式:以URL字串本身传递数据参数,在服务器端可以从'QUERY_STRING'这个变量中直接读取,效率较高,但缺乏安全性,也无法来处理复杂的数据(只能是字符串,比如在 ...
- python学习音频-详解python播放音频的三种方法
第一种 使用pygame模块 pygame.mixer.init() pygame.mixer.music.load(self.wav_file) pygame.mixer.music.set_vol ...
- python读取文件多行内容-Python逐行读取文件内容的方法总结
Python四种逐行读取文件内容的方法 下面四种Python逐行读取文件内容的方法, 分析了各种方法的优缺点及应用场景,以下代码在python3中测试通过, python2中运行部分代码已注释,稍加修 ...
- python可以播放音乐吗_详解python播放音频的三种方法
第一种 使用pygame模块 pygame.mixer.init() pygame.mixer.music.load(self.wav_file) pygame.mixer.music.set_vol ...
- python改文件名_通过python顺序修改文件名字的方法
通过python顺序修改文件名字的方法 更新时间:2018年07月11日 11:48:55 作者:longma666666 今天小编就为大家分享一篇通过python顺序修改文件名字的方法,具有很好的参 ...
- python调用cmd命令释放端口_详解python调用cmd命令三种方法
目前我使用到的python中执行cmd的方式有三种 使用os.system("cmd") 该方法在调用完shell脚本后,返回一个16位的二进制数,低位为杀死所调用脚本的信号号码, ...
最新文章
- 攻防世界php2_攻防世界-php2
- Linux系统gdb工具使用,使用 GDB 工具调试 Go
- HelloCharts-android 之饼状图的使用
- 计算机考研:河南有哪些性价比高的学校?
- java i o中文版_Java文件I/O的三种方法
- 函数04 - 零基础入门学习C语言35
- micropython仿真器_Micropython教程之TPYBoard DIY超声波测距仪实例演示
- 记录用户转成超级用户的文件名字_一分钟了解Linux用户
- birt报表模板只打印了第一行_财务系统全套表格模板201个!成为同事眼中的红人!低调分享...
- vue3.0 抽奖 小功能
- Android IPC(一)跨进程通讯的几种方式、作用
- Python爬虫从入门到精通:(14)验证码识别_Python涛哥
- [LTE 资源分配方法]资源池 resource pools
- 流程图设计(泳道图 | 任务流程图 | 页面流程图)
- 理解java的内存结构——运行时数据区域
- 冻结html表格标题列,HTML表格冻结第一列 | 学步园
- 0x00000116错误代码 nvlddmkm.sys 蓝屏
- MVC框架运行流程和目录结构
- 星级评价,点击星星进行评分
- 王道OS-磁盘存储器管理
热门文章
- bulter机器人_盘点:外国仓库里的仓储物流机器人
- 【报告分享】2021美伊白皮书-阿里妈妈CBE(附下载)
- css文字定位最右边,css 靠右但是不要顶在右边 有点距离 怎么写
- 需求澄清checklist
- 联想G510进入BIOS的两种方法
- 解决windows下 vs控制台中文显示乱码问题
- [深度学习]Part2 决策树Ch07——【DeepBlue学习笔记】
- 小程序全局悬浮窗_小程序悬浮窗-微信小程序制作
- 【IOS】委托(delegate)和协议(protocol)
- 苹果MacBook Air对比华为Matebook X Pro,如何选择