软件加密技术,python制作一个超强的加密软件

使用python做一个加密资料的软件,可加密应用程序、文件、压缩包等多种文件格式,不可直接加密文件夹,可以先用压缩包打包在加密。加密后的文件后缀不可乱改,否则解密会失败。程序内没有加入加密和解密成功的提示信息。

加密使用的是双层MD5加密

首先导入库

私信小编01即可获取大量python学习资源

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,解密后会恢复原来的后缀名

相关文章

Python中的函数(二) 在上一篇文章中提到了Python中函数的定...
Python中的字符串 可能大多数人在学习C语言的时候,最先接触...
Python 面向对象编程(一) 虽然Python是解释性语言,但是它...
Python面向对象编程(二) 在前面一篇文章中谈到了类的基本定...
Python中的函数(一) 接触过C语言的朋友对函数这个词肯定非...
在windows下如何快速搭建web.py开发框架 用Python进行web开发...