用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("关注博主不迷路!!!\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加密软件内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Python Des加密解密如何实现软件注册码机器码

    这篇文章主要介绍了Python Des加密解密如何实现软件注册码机器码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 原理 判断路径下是否存在识别文件,若存在就解密对比,若不存在就进入机器码注册: 获取系统C盘序列号作为识别ID,并添加随机数作为混淆,生成最终机器码. 将机器码发给软件开发者,开发者将机器码解密后,添加自己的标识符号并加密生成key,发给用户. 用户输入key,程序对比并保存. 用户下次打开软件时,重新开始步骤'1'. 说明 加

  • Python教程自己实现软件加密功能

    目录 原理 加密操作: 解密操作: 生成随机密钥: 加密单元: 解密单元: 加密文本文件 解密文件 基础知识 在 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

  • 用python实现超强的加密软件

    目录 前言 步骤 完整代码: 总结 前言 使用python做一个加密资料的软件,可加密应用程序.文件.压缩包等多种文件格式,不可直接加密文件夹,可以先用压缩包打包在加密.加密后的文件后缀不可乱改,否则解密会失败.程序内没有加入加密和解密成功的提示信息. 加密使用的是双层MD5加密 步骤 首先导入库 import os import hashlib 读取文件与写入文件 a = open(name_1, "rb") #读取文件 b = open(data, "wb")

  • python如何实现DES加密

    加密流程 首先说一下置换的意思,比如说有5678这个字符串,置换表为2143,置换表中的数表示的是位置,所以字符串变成6587.所有的置换表在程序中.(S盒置换不一样,会另外说明) 密钥部分 把8位字符串密钥变成2进制(好像密钥只可以是8位,这一块我也没有搞太清楚) 64位密钥进行PC1置换,变成56位,因为以前DES是用硬件实现的,所以8,16,24,32,40,48,56,64位为校验位,不记入密钥部分.但是我们现在是用软件实现,所以这8位需要去掉,再打乱顺序. 将56位密钥对半分L0和R0

  • Python编程密码学文件加密与解密代码解析

    目录 本章要点 1 纯文本文件 2 使用置换密码加密文件的源代码 transpositionFileCipher.py 3 运行置换密码加密文件程序的样例 4 文件操作 4.1 打开文件 4.2 数据写入及文件关闭 4.3 读取文件 5 创建main()函数 6 检查文件是否存在 6.1 os.path.exists() 方法 6.2 使用os.path.exists()方法检查输入的文件是否存在 7 使用字符串方法令用户的输入更灵活 7.1 upper().lower()和title()字符串

  • python实现的DES加密算法和3DES加密算法实例

    本文实例讲述了python实现的DES加密算法和3DES加密算法.分享给大家供大家参考.具体实现方法如下: ############################################################################# # Documentation # ############################################################################# # Author: Todd Whitema

  • python文件的md5加密方法

    本文实例讲述了python文件的md5加密方法.分享给大家供大家参考,具体如下: 简单模式: from hashlib import md5 def md5_file(name): m = md5() a_file = open(name, 'rb') #需要使用二进制格式读取文件内容 m.update(a_file.read()) a_file.close() return m.hexdigest() if __main__ == '__init__': print md5_file('d:/

  • Python基于DES算法加密解密实例

    本文实例讲述了Python基于DES算法加密解密实现方法.分享给大家供大家参考.具体实现方法如下: #coding=utf-8 from functools import partial import base64 class DES(object): """ DES加密算法 interface: input_key(s, base=10), encode(s), decode(s) """ __ip = [ 58,50,42,34,26,18,

  • python实现文件快照加密保护的方法

    本文实例讲述了python实现文件快照加密保护的方法.分享给大家供大家参考.具体如下: 这段代码可以对指定的目录进行扫描,包含子目录,对指定扩展名的文件进行SHA-1加密后存储在cvs文件,以防止文件被篡改 调用方法:python snapper.py > todayCheck.csv # Hello, this is a script written in Python. See http://www.pyhon.org # # Snapper 1.2p # # This script wil

  • python有证书的加密解密实现方法

    本文实例讲述了python有证书的加密解密实现方法.分享给大家供大家参考.具体实现方法如下: 最近在做python的加解密工作,同时加完密的串能在php上能解出来,网上也找了一些靠谱的资料,刚好也有时间我就总结了一下python在加密与解密这块的代码,今后可能还能用的上.相对于php而言python这块加解密组件较多的,分别是: python-crypto - 这个组件是基本组件,使用的函式相对比较复杂. ezPyCrypto - 相对简单,但他作出来的公私钥无法与其他程序相兼容     SSL

  • python使用7z解压软件备份文件脚本分享

    要求安装: 1.Python2.7z解压软件 backup_2.py 复制代码 代码如下: # Filename: backup_2.py '''Backup files.    Version: V2, based on Python 3.3    Usage: backup.py -s:"dir1|dir2|..." -t:"target_dir" [-c:"comment"]        -s: The source directorie

  • python实现无证书加密解密实例

    本文实例讲述了python实现无证书加密解密的方法,分享给大家供大家参考.具体实现方法如下: 无证书加密就是双方不需要维护证书,加密与解密只需要双方约定一个key就可以,无证书加解密的方式应用更广泛一些,python官方也有这方面的相关例子说明,地址是:https://pypi.python.org/pypi/pycrypto,主要用的是from Crypto.Cipher import AES这个模块,代码如下: 复制代码 代码如下: ''' /** * AES加密字符串 * * @param

随机推荐