用python实现超强的加密软件
作者:小木_. 发布时间:2022-12-06 11:42:50
前言
使用python做一个加密资料的软件,可加密应用程序、文件、压缩包等多种文件格式,不可直接加密文件夹,可以先用压缩包打包在加密。加密后的文件后缀不可乱改,否则解密会失败。程序内没有加入加密和解密成功的提示信息。
加密使用的是双层MD5加密
步骤
首先导入库
import os
import hashlib
读取文件与写入文件
a = open(name_1, "rb") #读取文件
b = open(data, "wb") #写入文件
a.close() #保存退出
b.close() #保存退出
使用ord进行编码,用bytes进行解码,内置索引进行循环读取密码,挨个读取进行编码写入,
#加密及解密
def Encryption_and_decryption():
count = 0 #索引
for now in a:
for nowByte in now:
newByte = nowByte ^ ord(password_data[count % len(password_data)]) #循环遍历出密码的ord值,单个循环
count += 1
b.write(bytes([newByte])) #转换
Encryption_and_decryption()
用ord进行编码可以看到会出现一点问题,就是加密后的文件,如文本文件,如果加密的密码是‘qwer’,编码则会将q w e r分别用bytes编码为 113 119 101 114,然后把编码后的数字在循环内一个一个插入到文本内,进行代替,解密也是同样原理,但是有一个致命缺陷,就是假如你的密码是”qwer“,解码的时候输入一个密码 q 即可全部解码成功,这个是一个缺陷。
所以我使用MD5进行加密,然后再进行编码,MD5大家都知道,不同的MD5值是由不同的字母、数字、字符串组合进行转换而成,MD5也区分大小写,这也让我们的加密软件更安全一步
hl = hashlib.md5()
hl.update(password.encode(encoding='utf-8'))
password_list = hl.hexdigest()
为了我们的资料,我将MD5进行了二次加密,用已经加密后的MD5值再次进行加密,然后将第一个MD5值和第二个MD5值进行组合(非相加),组成高强度的加密
#使用MD5进行加密(双层加密)
hl = hashlib.md5()
hl.update(password.encode(encoding='utf-8'))
password_list = hl.hexdigest()
hl.update(password_list.encode(encoding='utf-8'))
password_list2 = hl.hexdigest()
password_data = password_list+password_list2
解码也是同样原理,将密码进行MD5加密再加密,然后进入文件进行编码转换,如果密码正确则文件不会有乱码,如果密码错误则文件内都是乱码,这个程序是没有解码和加密成功的提示。
由于路径多种多样,程序会因此运行错误,所以我用replace进行路径’\ /‘转换,把所有的’\\‘和’\‘转换为’/‘,用于程序方便读取
name_1 = name_1.replace("\\", "/") # 替换
data = data.replace("\\", "/") # 替换
为了方便大家进行使用,提取进行程序的检测,检测是否存在该文件,或路径的错误
if os.path.exists(name_1) == True:
pass
else:
print('请检查是否路径错误或不存在该文件!!!!')
os.system('pause')
exit()
保存的路径不可缺少,如果保存的路径没有输入直接跳过则会默认为读取程序的位置,如果读取程序的路径也没有写入,则会以读取程序的根目录为存储地进行保存
if name_1.split(".")[1][-4:] == 'DATA':
F = name_1.split(".")[1].replace("DATA", "")
if os.path.split(data)[0] == '':
if os.path.split(name_1)[0] == '':
data = os.path.split(name_1)[-1].split(".")[0] + '.' + F
else:
data = os.path.split(name_1)[0] + '/' + os.path.split(name_1)[-1].split(".")[0] + '.' + F
else:
data = data + '/' + os.path.split(name_1)[-1].split(".")[0] + '.' + F
else:
# 保存路径
if os.path.split(data)[0] == '':
if os.path.split(name_1)[0] == '':
data = name_1.split(".")[1] # 后缀
data = os.path.split(name_1)[-1].split(".")[0] + '.' + data + 'DATA'
else:
data = name_1.split(".")[1] # 后缀
data = os.path.split(name_1)[0] + '/' + os.path.split(name_1)[-1].split(".")[0] + '.' + data + 'DATA'
else:
name_3 = name_1.split(".")[1] # 后缀
data = data + '/' + os.path.split(name_1)[-1].split(".")[0] + '.' + name_3 + 'DATA'
这个程序加密后会在程序后缀出现DATA,这个是为了方便清楚的知道什么是已加密程序,而且还可以让软件程序检测是否是已经加密过的程序,方便解密。
完整代码:
import os
import hashlib
print("-------------------------------------软件加密工具-------------------------------------")
print("关注博主不迷路!!!\nhttps://jiangongfang.blog.csdn.net/\nhttps://blog.51cto.com/u_15449377")
print("使用告知:\n【加密后的文件后缀会多出DATA,是为了方便软件检测,请勿乱改加密后的后缀名】")
print("【保存文件默认路径 为加密文件或解密文件的当前目录,不是软件的当前目录】")
print("【要加密或解密的文件命名不可有“./\”字符,否则会出错】")
print("-------------------------------------软件加密工具-------------------------------------\n")
name_1 = input('输入要加密或解密的文件名含后缀:')
#判断是否存在该文件
if os.path.exists(name_1) == True:
pass
else:
print('请检查是否路径错误或不存在该文件!!!!')
os.system('pause')
exit()
password = input('请输入要加密或解密的密码:')
data = input('输入要保存文件的路径位置(可不填):')
name_1 = name_1.replace("\\", "/") # 替换
data = data.replace("\\", "/") # 替换
if name_1.split(".")[1][-4:] == 'DATA':
F = name_1.split(".")[1].replace("DATA", "")
if os.path.split(data)[0] == '':
if os.path.split(name_1)[0] == '':
data = os.path.split(name_1)[-1].split(".")[0] + '.' + F
else:
data = os.path.split(name_1)[0] + '/' + os.path.split(name_1)[-1].split(".")[0] + '.' + F
else:
data = data + '/' + os.path.split(name_1)[-1].split(".")[0] + '.' + F
else:
# 保存路径
if os.path.split(data)[0] == '':
if os.path.split(name_1)[0] == '':
data = name_1.split(".")[1] # 后缀
data = os.path.split(name_1)[-1].split(".")[0] + '.' + data + 'DATA'
else:
data = name_1.split(".")[1] # 后缀
data = os.path.split(name_1)[0] + '/' + os.path.split(name_1)[-1].split(".")[0] + '.' + data + 'DATA'
else:
name_3 = name_1.split(".")[1] # 后缀
data = data + '/' + os.path.split(name_1)[-1].split(".")[0] + '.' + name_3 + 'DATA'
a = open(name_1, "rb") #读取文件
b = open(data, "wb") #写入文件
#使用MD5进行加密(双层加密)
hl = hashlib.md5()
hl.update(password.encode(encoding='utf-8'))
password_list = hl.hexdigest()
hl.update(password_list.encode(encoding='utf-8'))
password_list2 = hl.hexdigest()
password_data = password_list+password_list2
#加密及解密
def Encryption_and_decryption():
count = 0 #索引
for now in a:
for nowByte in now:
newByte = nowByte ^ ord(password_data[count % len(password_data)]) #循环遍历出密码的ord值,单个循环
count += 1
b.write(bytes([newByte])) #转换
Encryption_and_decryption()
a.close()
b.close()
os.system('pause')
可以看到已经加密的程序后缀有DATA,解密后会恢复原来的后缀名
总结
来源:https://blog.csdn.net/weixin_46625757/article/details/122428509


猜你喜欢
- tensorflow里面给出了一个函数用来读取图像,不过得到的结果是最原始的图像,是咩有经过解码的图像,这个函数为tf.gfile.Fast
- Celery是一个异步的任务队列(也叫做分布式任务队列),一个简单,灵活,可靠的分布式系统,用于处理大量消息,同时为操作提供维护此类系统所需
- 如下所示:def append(arr, values, axis=None): """ Append val
- Python + OpenCV 直接上代码import cv2 import numpy as np from matplotlib imp
- 异常异常是程序发生错误的信号,程序一旦出错就会抛出异常,程序的运行随之终止。# 异常处理的三个特征- 异常的追踪信息- 异常的类型- 异常的
- 本文实例讲述了python实现的多线程端口扫描功能。分享给大家供大家参考,具体如下:下面的程序给出了对给定的ip主机进行多线程扫描的Pyth
- 方法1: 代码如下:truncate table TableName 删除表中的所有的数据的同时,将自动增长清零。 如果有外键参考这个表,这
- HTML转PDF:1.页面底层实现——Vue:最低兼容ie102.实现思路:1> 使用html2canvas.js将网页转换为图片2&
- 爬虫与发爬虫的厮杀,一方为了拿到数据,一方为了防止爬虫拿到数据,谁是最后的赢家?重新理解爬虫中的一些概念爬虫:自动获取网站数据的程序反爬虫:
- 爬取某人的微博数据,把某人所有时间段的微博数据都爬下来。具体思路:创建driver-----get网页----找到并提取信息-----保存c
- 在 HTML 页面中嵌入 JavaScript 脚本需要使用 <script> 标签,用户可以在 <script>
- 一、uni.navigateTo(OBJECT)保留当前页面,跳转到应用内的某个页面,使用uni.navigateBack可以返回到原页面u
- 一基础理解: var e = document.getElementById("selectId");e. option
- “表情包”是当前社交软件上不可或缺的交流方式,难以用文字表达的意思,发一个“表情包”,对方就能心领神会。下面是小派制作的一个表情包,准确地讲
- cuDNN使用非确定性算法,并且可以使用torch.backends.cudnn.enabled = False来进行禁用如果设置为torc
- 这样处理的弊端是:如果数据量大,子分类很多,达到4级以上,这方法处理极端占用数据库连接池 对性能影响很大。 如果用SQL下面的CTE递归处理
- 最近肺炎的发展速度属实有点恐怖。刚知道python的pyecharts这个库,想到pyecharts可视化的特点,正好可以扒一下肺炎实时播报
- 1、创建存储过程 create or replace procedure test(var_name_1 in type,var_name_
- 一、 [::-1]import numpy as npimport numpy as npx = np.arange(1, 6)print(
- 负责为网页编程语言提供标准化服务的W3C组织(World Wide Web Consortium)近日开始修改超文本标记语言的定义,计划为该