欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用python實現(xiàn)超強的加密軟件

 更新時間:2022年01月13日 08:43:16   作者:小木_.  
大家好,本篇文章主要講的是用python實現(xiàn)超強的加密軟件,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽

前言

使用python做一個加密資料的軟件,可加密應(yīng)用程序、文件、壓縮包等多種文件格式,不可直接加密文件夾,可以先用壓縮包打包在加密。加密后的文件后綴不可亂改,否則解密會失敗。程序內(nèi)沒有加入加密和解密成功的提示信息。

加密使用的是雙層MD5加密

步驟

首先導入庫

import os
import hashlib

讀取文件與寫入文件

a = open(name_1, "rb")  #讀取文件
b = open(data, "wb")    #寫入文件
a.close()    #保存退出
b.close()    #保存退出

使用ord進行編碼,用bytes進行解碼,內(nèi)置索引進行循環(huán)讀取密碼,挨個讀取進行編碼寫入,

#加密及解密
def Encryption_and_decryption():
    count = 0  #索引
    for now in a:
        for nowByte in now:
            newByte = nowByte ^ ord(password_data[count % len(password_data)])  #循環(huán)遍歷出密碼的ord值,單個循環(huán)
            count += 1
            b.write(bytes([newByte]))   #轉(zhuǎn)換
Encryption_and_decryption()

用ord進行編碼可以看到會出現(xiàn)一點問題,就是加密后的文件,如文本文件,如果加密的密碼是‘qwer’,編碼則會將q w e r分別用bytes編碼為 113 119 101 114,然后把編碼后的數(shù)字在循環(huán)內(nèi)一個一個插入到文本內(nèi),進行代替,解密也是同樣原理,但是有一個致命缺陷,就是假如你的密碼是”qwer“,解碼的時候輸入一個密碼 q 即可全部解碼成功,這個是一個缺陷。

所以我使用MD5進行加密,然后再進行編碼,MD5大家都知道,不同的MD5值是由不同的字母、數(shù)字、字符串組合進行轉(zhuǎn)換而成,MD5也區(qū)分大小寫,這也讓我們的加密軟件更安全一步

hl = hashlib.md5()
hl.update(password.encode(encoding='utf-8'))
password_list = hl.hexdigest()

為了我們的資料,我將MD5進行了二次加密,用已經(jīng)加密后的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加密再加密,然后進入文件進行編碼轉(zhuǎn)換,如果密碼正確則文件不會有亂碼,如果密碼錯誤則文件內(nèi)都是亂碼,這個程序是沒有解碼和加密成功的提示。

由于路徑多種多樣,程序會因此運行錯誤,所以我用replace進行路徑’\ /‘轉(zhuǎn)換,把所有的’\\‘和’\‘轉(zhuǎn)換為’/‘,用于程序方便讀取

name_1 = name_1.replace("\\", "/")  # 替換
data = data.replace("\\", "/")  # 替換

為了方便大家進行使用,提取進行程序的檢測,檢測是否存在該文件,或路徑的錯誤

if os.path.exists(name_1) == True:
    pass
else:
    print('請檢查是否路徑錯誤或不存在該文件!?。?!')
    os.system('pause')
    exit()

保存的路徑不可缺少,如果保存的路徑?jīng)]有輸入直接跳過則會默認為讀取程序的位置,如果讀取程序的路徑也沒有寫入,則會以讀取程序的根目錄為存儲地進行保存

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'

這個程序加密后會在程序后綴出現(xiàn)DATA,這個是為了方便清楚的知道什么是已加密程序,而且還可以讓軟件程序檢測是否是已經(jīng)加密過的程序,方便解密。

完整代碼:

import os
import hashlib
 
 
print("-------------------------------------軟件加密工具-------------------------------------")
print("關(guān)注博主不迷路?。?!\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)])  #循環(huán)遍歷出密碼的ord值,單個循環(huán)
            count += 1
            b.write(bytes([newByte]))   #轉(zhuǎn)換
Encryption_and_decryption()
a.close()
b.close()
 
os.system('pause')

可以看到已經(jīng)加密的程序后綴有DATA,解密后會恢復原來的后綴名

 總結(jié)

到此這篇關(guān)于用python實現(xiàn)超強的加密軟件的文章就介紹到這了,更多相關(guān)python加密軟件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 利用python對excel中一列的時間數(shù)據(jù)更改格式操作

    利用python對excel中一列的時間數(shù)據(jù)更改格式操作

    這篇文章主要介紹了利用python對excel中一列的時間數(shù)據(jù)更改格式操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • 使用Python發(fā)現(xiàn)隱藏的wifi

    使用Python發(fā)現(xiàn)隱藏的wifi

    今天與大家一起分享使用Python來發(fā)現(xiàn)隱藏的wifi,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03
  • Django發(fā)送郵件和itsdangerous模塊的配合使用解析

    Django發(fā)送郵件和itsdangerous模塊的配合使用解析

    這篇文章主要介紹了Django發(fā)送郵件和itsdangerous模塊的配合使用解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • 深入淺析python定時殺進程

    深入淺析python定時殺進程

    這篇文章主要介紹了深入淺析python定時殺進程的相關(guān)資料,需要的朋友可以參考下
    2016-06-06
  • Python?pickle模塊實現(xiàn)Python對象持久化存儲

    Python?pickle模塊實現(xiàn)Python對象持久化存儲

    這篇文章主要介紹了Python?pickle模塊實現(xiàn)Python對象持久化存儲,pickle?是?python?語言的一個標準模塊,和python安裝時共同安裝好的一個模塊。下文基于pickle模塊展開實現(xiàn)Python對象持久化存儲的詳細內(nèi)容,需要的朋友可以參考一下
    2022-05-05
  • 探索Python fcntl模塊文件鎖和文件控制的強大工具使用實例

    探索Python fcntl模塊文件鎖和文件控制的強大工具使用實例

    這篇文章主要介紹了Python fcntl模塊文件鎖和文件控制的強大工具使用實例探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2024-01-01
  • python3正則提取字符串里的中文實例

    python3正則提取字符串里的中文實例

    今天小編就為大家分享一篇python3正則提取字符串里的中文實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • Django Form and ModelForm的區(qū)別與使用

    Django Form and ModelForm的區(qū)別與使用

    這篇文章主要介紹了Django Form and ModelForm的區(qū)別與使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • Python基于SMTP發(fā)送郵件的方法

    Python基于SMTP發(fā)送郵件的方法

    這篇文章主要介紹了Python基于SMTP 發(fā)送郵件的方法,幫助大家更好的理解和學習使用python,感興趣的朋友可以了解下
    2021-03-03
  • Python3實現(xiàn)購物車功能

    Python3實現(xiàn)購物車功能

    這篇文章主要為大家詳細介紹了Python3實現(xiàn)購物車功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04

最新評論