溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么用python實(shí)現(xiàn)超強(qiáng)的加密軟件

發(fā)布時(shí)間:2022-01-13 10:46:16 來(lái)源:億速云 閱讀:168 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章將為大家詳細(xì)講解有關(guān)怎么用python實(shí)現(xiàn)超強(qiáng)的加密軟件,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

步驟

首先導(dǎo)入庫(kù)

import os
import hashlib

讀取文件與寫入文件

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

使用ord進(jìn)行編碼,用bytes進(jìn)行解碼,內(nèi)置索引進(jìn)行循環(huán)讀取密碼,挨個(gè)讀取進(jì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值,單個(gè)循環(huán)
            count += 1
            b.write(bytes([newByte]))   #轉(zhuǎn)換
Encryption_and_decryption()

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

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

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

為了我們的資料,我將MD5進(jìn)行了二次加密,用已經(jīng)加密后的MD5值再次進(jìn)行加密,然后將第一個(gè)MD5值和第二個(gè)MD5值進(jìn)行組合(非相加),組成高強(qiáng)度的加密

#使用MD5進(jìn)行加密(雙層加密)
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

解碼也是同樣原理,將密碼進(jìn)行MD5加密再加密,然后進(jìn)入文件進(jìn)行編碼轉(zhuǎn)換,如果密碼正確則文件不會(huì)有亂碼,如果密碼錯(cuò)誤則文件內(nèi)都是亂碼,這個(gè)程序是沒(méi)有解碼和加密成功的提示。

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

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

為了方便大家進(jìn)行使用,提取進(jìn)行程序的檢測(cè),檢測(cè)是否存在該文件,或路徑的錯(cuò)誤

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

保存的路徑不可缺少,如果保存的路徑?jīng)]有輸入直接跳過(guò)則會(huì)默認(rèn)為讀取程序的位置,如果讀取程序的路徑也沒(méi)有寫入,則會(huì)以讀取程序的根目錄為存儲(chǔ)地進(jìn)行保存

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'

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

完整代碼:

import os
import hashlib
 
 
print("-------------------------------------軟件加密工具-------------------------------------")
print("關(guān)注博主不迷路?。?!\nhttps://jiangongfang.blog.csdn.net/\nhttps://blog.51cto.com/u_15449377")
print("使用告知:\n【加密后的文件后綴會(huì)多出DATA,是為了方便軟件檢測(cè),請(qǐng)勿亂改加密后的后綴名】")
print("【保存文件默認(rèn)路徑 為加密文件或解密文件的當(dāng)前目錄,不是軟件的當(dāng)前目錄】")
print("【要加密或解密的文件命名不可有“./\”字符,否則會(huì)出錯(cuò)】")
print("-------------------------------------軟件加密工具-------------------------------------\n")
name_1 = input('輸入要加密或解密的文件名含后綴:')
#判斷是否存在該文件
if os.path.exists(name_1) == True:
    pass
else:
    print('請(qǐng)檢查是否路徑錯(cuò)誤或不存在該文件?。。?!')
    os.system('pause')
    exit()
 
password = input('請(qǐng)輸入要加密或解密的密碼:')
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進(jìn)行加密(雙層加密)
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值,單個(gè)循環(huán)
            count += 1
            b.write(bytes([newByte]))   #轉(zhuǎn)換
Encryption_and_decryption()
a.close()
b.close()
 
os.system('pause')

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

怎么用python實(shí)現(xiàn)超強(qiáng)的加密軟件

關(guān)于“怎么用python實(shí)現(xiàn)超強(qiáng)的加密軟件”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI