基于python实现文件加密功能


Posted in Python onJanuary 06, 2020

这篇文章主要介绍了基于python实现文件加密功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

生活中,有时候我们需要对一些重要的文件进行加密,Python 提供了诸如 hashlib,base64 等便于使用的加密库。

但对于日常学习而言,我们可以借助异或操作,实现一个简单的文件加密程序,从而强化自身的编程能力。

基础知识

在 Python 中异或操作符为:^,也可以记作 XOR。按位异或的意思是:相同值异或为 0,不同值异或为 1。具体来讲,有四种可能:0 ^ 0 = 0,0 ^ 1 = 1, 1 ^ 0 = 1, 1 ^ 1 = 0。我们还可总结出规律(A 为 0 或 1):0 和 A 异或为 A本身;1 和 A 异或为 A 反。

让我们想看看一位二进制数满足的性质:

一位二进制数与自身的异或值为 0

b ^ b = 0

异或操作满足交换律

a ^ b ^ c = a ^ (b ^ c) = (a ^ b) ^ c

0 与 a 的异或为 a

(a ^ b) ^ b = a ^ (b ^ b) = a ^ 0 = a

易知,对任意长二进制数都满足上述性质。

原理

通过了解异或操作的性质,加密原理就非常清晰了。

加密操作:

首先将文件转换成二进制数,再生成与该二进制数等长的随机密钥,将二进制数与密钥进行异或操作,得到加密后的二进制数。

解密操作:

将加密后的二进制程序与密钥进行异或操作,就得到原二进制数,最后将原二进制数恢复成文本文件。

生成随机密钥:
secrets 库是 Python 3.6 引入的伪随机数模块,适合生成随机密钥。token_bytes 函数接受一个 int 参数,用于指定随机字节串的长度。int.from_bytes 把字节串转换为 int,也就是我们需要的二进制数。

from secrets import token_bytes

def random_key(length):
  key = token_bytes(nbytes=length)
  key_int = int.from_bytes(key, 'big')
  return key_int

加密单元:

encrypt 函数接受一个 str 对象,返回元组 (int, int)。通过 encode 方法,我们将字符串编码成字节串。int.from_bytes 函数将字节串转换为 int 对象。最后对二进制对象和随机密钥进行异或操作,就得到了加密文本。

def encrypt(raw):
  raw_bytes = raw.encode()
  raw_int = int.from_bytes(raw_bytes, 'big')
  key_int = random_key(len(raw_bytes))
  return raw_int ^ key_int, key_int

解密单元:

decrypt 接受两个 int 对象,分别为加密文本和随机密钥。首先对两者进行异或操作,计算解密出来的 int 对象所占比特数。decrypted.bit_length 函数得到的是二进制数的位数,除以 8 可以得到所占比特大小。为了防止,1 ~ 7 位的二进制数整除 8 得到 0,所以要加上 7,然后再进行整除 8 的操作。使用 int.to_bytes 函数将解密之后的 int 的对象转换成 bytes 对象。最后通过 decode 方法,将字节串转换成字符串。

def decrypt(encrypted, key_int):
  decrypted = encrypted ^ key_int
  length = (decrypted.bit_length() + 7) // 8
  decrypted_bytes = int.to_bytes(decrypted, length, 'big') 
  return decrypted_bytes.decode()

利用上述函数,我们可以很轻松对文本文件进行加密、解密操作。

>>> raw = '画图省识春风面,环?空归夜月魂'
>>> encrypted = encrypt(raw)
>>> encrypted
(217447100157746604585...,
 9697901906831571319...)
>>> decrypt(*encrypted)
'画图省识春风面,环?空归夜月魂'

加密文本文件

path 为待加密文件的地址,如果不指定密钥地址,则在该目录下新建目录和文件。

import json
from pathlib import Path

def encrypt_file(path, key_path=None, *, encoding='utf-8'):
  path = Path(path)
  cwd = path.cwd() / path.name.split('.')[0]
  path_encrypted = cwd / path.name 
  if key_path is None:
    key_path = cwd / 'key'
  if not cwd.exists():
    cwd.mkdir()
    path_encrypted.touch()
    key_path.touch()

  with path.open('rt', encoding=encoding) as f1, \
    path_encrypted.open('wt', encoding=encoding) as f2, \
      key_path.open('wt', encoding=encoding) as f3:
    encrypted, key = encrypt(f1.read())
    json.dump(encrypted, f2)
    json.dump(key, f3)

解密文件

#Python学习群592539176
def decrypt_file(path_encrypted, key_path=None, *, encoding='utf-8'):
  path_encrypted = Path(path_encrypted)
  cwd = path_encrypted.cwd()
  path_decrypted = cwd / 'decrypted' 
  if not path_decrypted.exists():
    path_decrypted.mkdir()
    path_decrypted /= path_encrypted.name
    path_decrypted.touch()
  if key_path is None:
    key_path = cwd / 'key'
  with path_encrypted.open('rt', encoding=encoding) as f1, \
    key_path.open('rt', encoding=encoding) as f2, \
    path_decrypted.open('wt', encoding=encoding) as f3:
    decrypted = decrypt(json.load(f1), json.load(f2))
    f3.write(decrypted)

执行完加密、解密文件操作,得到的解密文件与原文件相同,示意图如下:

基于python实现文件加密功能

以上就是 Python 加密文件的全部内容,还请大家多多转发支持。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python sys模块sys.path使用方法示例
Dec 04 Python
python调用java模块SmartXLS和jpype修改excel文件的方法
Apr 28 Python
Django验证码的生成与使用示例
May 20 Python
matplotlib 纵坐标轴显示数据值的实例
May 25 Python
Python numpy中矩阵的基本用法汇总
Feb 12 Python
彻底理解Python中的yield关键字
Apr 01 Python
Python3实现的旋转矩阵图像算法示例
Apr 03 Python
Python使用正则表达式分割字符串的实现方法
Jul 16 Python
Opencv图像处理:如何判断图片里某个颜色值占的比例
Jun 03 Python
python 实现德洛内三角剖分的操作
Apr 22 Python
Django实现drf搜索过滤和排序过滤
Jun 21 Python
Python socket如何解析HTTP请求内容
Feb 12 Python
Pytorch 实现冻结指定卷积层的参数
Jan 06 #Python
如何使用python实现模拟鼠标点击
Jan 06 #Python
pytorch 实现查看网络中的参数
Jan 06 #Python
Python3 虚拟开发环境搭建过程(图文详解)
Jan 06 #Python
Pytorch根据layers的name冻结训练方式
Jan 06 #Python
Windows下python3安装tkinter的问题及解决方法
Jan 06 #Python
带你彻底搞懂python操作mysql数据库(cursor游标讲解)
Jan 06 #Python
You might like
多人战的战术与战略
2020/03/04 星际争霸
FCKeditor添加自定义按钮
2008/03/27 PHP
php 面试碰到过的问题 在此做下记录
2011/06/09 PHP
php 数组动态添加实现代码(最土团购系统的价格排序)
2011/12/30 PHP
php银联网页支付实现方法
2015/03/04 PHP
PHP和MySql中32位和64位的整形范围是多少
2016/02/18 PHP
php compact 通过变量创建数组
2016/11/15 PHP
PHP设计模式之原型设计模式原理与用法分析
2018/04/25 PHP
js鼠标滑轮滚动事件绑定的简单实例(兼容主流浏览器)
2014/01/14 Javascript
JS实现从表格中动态删除指定行的方法
2015/03/31 Javascript
简单的网页广告特效实例
2017/08/19 Javascript
快速搭建vue2.0+boostrap项目的方法
2018/04/09 Javascript
vue项目中vue-i18n和element-ui国际化开发实现过程
2018/04/25 Javascript
详解node Async/Await 更好的异步编程解决方案
2018/05/10 Javascript
webpack4打包vue前端多页面项目
2018/09/17 Javascript
使用异步组件优化Vue应用程序的性能
2019/04/28 Javascript
Postman如何实现参数化执行及断言处理
2020/07/28 Javascript
python list使用示例 list中找连续的数字
2014/01/27 Python
从零学python系列之教你如何根据图片生成字符画
2014/05/23 Python
python下MySQLdb用法实例分析
2015/06/08 Python
Python基于回溯法子集树模板解决0-1背包问题实例
2017/09/02 Python
python+selenium实现京东自动登录及秒杀功能
2017/11/18 Python
python2与python3共存问题的解决方法
2018/09/18 Python
在python3中使用shuffle函数要注意的地方
2020/02/28 Python
python简单实现9宫格图片实例
2020/09/03 Python
使用HTML5 Canvas绘制圆角矩形及相关的一些应用举例
2016/03/22 HTML / CSS
Wedgwood美国官网:英国骨瓷,精美礼品及家居装饰
2018/02/17 全球购物
彪马土耳其官网:PUMA土耳其
2019/07/14 全球购物
新闻记者实习自我鉴定
2013/09/19 职场文书
小学生期末评语
2014/04/21 职场文书
师范生自荐信模板
2014/05/28 职场文书
十佳党员事迹材料
2014/08/28 职场文书
乡镇团委工作总结2015
2015/05/26 职场文书
田径运动会广播稿
2015/08/19 职场文书
500字作文之周记
2019/12/13 职场文书
Python开发五子棋小游戏
2022/04/28 Python