網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
前言
使用python做一個(gè)加密資料的軟件,可加密應(yīng)用程序、文件、壓縮包等多種文件格式,不可直接加密文件夾,可以先用壓縮包打包在加密。加密后的文件后綴不可亂改,否則解密會(huì)失敗。程序內(nèi)沒有加入加密和解密成功的提示信息。
加密使用的是雙層MD5加密
步驟
首先導(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)問題,就是加密后的文件,如文本文件,如果加密的密碼是‘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è)程序是沒有解碼和加密成功的提示。
由于路徑多種多樣,程序會(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)]有輸入直接跳過則會(huì)默認(rèn)為讀取程序的位置,如果讀取程序的路徑也沒有寫入,則會(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)加密過的程序,方便解密。
完整代碼:
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ù)原來的后綴名
?總結(jié)
原文鏈接:https://blog.csdn.net/weixin_46625757/article/details/122428509
相關(guān)推薦
- 2022-05-03 基于Python制作一款屏幕顏色提取器_python
- 2022-06-02 Apache?Pulsar結(jié)合Hudi構(gòu)建Lakehouse方案分析_服務(wù)器其它
- 2023-10-14 c/c++--__attribute__ 機(jī)制
- 2022-11-06 React中useEffect與生命周期鉤子函數(shù)的對(duì)應(yīng)關(guān)系說明_React
- 2022-09-18 Docker?Compose?搭建簡(jiǎn)單的Python網(wǎng)絡(luò)應(yīng)用程序(步驟詳解)_docker
- 2022-10-08 詳解C語(yǔ)言如何實(shí)現(xiàn)雙向帶頭循環(huán)鏈表_C 語(yǔ)言
- 2022-11-07 React?全面解析excel文件_React
- 2022-05-04 Jupyter?notebook運(yùn)行后打不開網(wǎng)頁(yè)的問題解決_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支