热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

用python实现超强的加密软件

大家好,本篇文章主要讲的是用python实现超强的加密软件,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收

前言

使用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("关注博主不迷路!!!
https://jiangongfang.blog.csdn.net/
https://blog.51cto.com/u_15449377")
print("使用告知:
【加密后的文件后缀会多出DATA,是为了方便软件检测,请勿乱改加密后的后缀名】")
print("【保存文件默认路径 为加密文件或解密文件的当前目录,不是软件的当前目录】")
print("【要加密或解密的文件命名不可有“./”字符,否则会出错】")
print("-------------------------------------软件加密工具-------------------------------------
")
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代码示例。 ... [详细]
  • 本文介绍了Swing组件的用法,重点讲解了图标接口的定义和创建方法。图标接口用来将图标与各种组件相关联,可以是简单的绘画或使用磁盘上的GIF格式图像。文章详细介绍了图标接口的属性和绘制方法,并给出了一个菱形图标的实现示例。该示例可以配置图标的尺寸、颜色和填充状态。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • 本文讨论了在Windows 8上安装gvim中插件时出现的错误加载问题。作者将EasyMotion插件放在了正确的位置,但加载时却出现了错误。作者提供了下载链接和之前放置插件的位置,并列出了出现的错误信息。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 怎么在PHP项目中实现一个HTTP断点续传功能发布时间:2021-01-1916:26:06来源:亿速云阅读:96作者:Le ... [详细]
  • 第四章高阶函数(参数传递、高阶函数、lambda表达式)(python进阶)的讲解和应用
    本文主要讲解了第四章高阶函数(参数传递、高阶函数、lambda表达式)的相关知识,包括函数参数传递机制和赋值机制、引用传递的概念和应用、默认参数的定义和使用等内容。同时介绍了高阶函数和lambda表达式的概念,并给出了一些实例代码进行演示。对于想要进一步提升python编程能力的读者来说,本文将是一个不错的学习资料。 ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • 图像因存在错误而无法显示 ... [详细]
  • 本文介绍了Android中的assets目录和raw目录的共同点和区别,包括获取资源的方法、目录结构的限制以及列出资源的能力。同时,还解释了raw目录中资源文件生成的ID,并说明了这些目录的使用方法。 ... [详细]
  • java drools5_Java Drools5.1 规则流基础【示例】(中)
    五、规则文件及规则流EduInfoRule.drl:packagemyrules;importsample.Employ;ruleBachelorruleflow-group ... [详细]
  • 本文详细介绍了使用C#实现Word模版打印的方案。包括添加COM引用、新建Word操作类、开启Word进程、加载模版文件等步骤。通过该方案可以实现C#对Word文档的打印功能。 ... [详细]
  • Python中sys模块的功能及用法详解
    本文详细介绍了Python中sys模块的功能及用法,包括对解释器参数和功能的访问、命令行参数列表、字节顺序指示符、编译模块名称等。同时还介绍了sys模块中的新功能和call_tracing函数的用法。推荐学习《Python教程》以深入了解。 ... [详细]
  • 本文介绍了在Linux系统下进行文件压缩与解压的常用命令,包括tar命令的基本使用和参数,以及gzip、bz2、compress、rar和zip等不同格式的压缩与解压方法。同时还提供了常见的压缩文件后缀名及对应的解压命令,方便用户进行文件的压缩和解压操作。 ... [详细]
author-avatar
H801_597
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有