經(jīng)常遇到百度網(wǎng)盤的壓縮文件加密了,今天我們就破解它!
實(shí)現(xiàn)思路
上篇文章給大家介紹了爆破密碼的思路,感興趣的朋友可以了解下。
其實(shí)都大同小異:無(wú)非就是字典爆破,就看你是有現(xiàn)成密碼字典,還是自己生成密碼字典,然后進(jìn)行循環(huán)輸入密碼,直到輸入正確位置?,F(xiàn)在很多都有防爆破限制,根本無(wú)法進(jìn)行暴力破解,但是似乎zip這種大家都是用比較簡(jiǎn)單的密碼而且沒(méi)有什么限制。
因此 實(shí)現(xiàn)思路就是
生成字典->輸入密碼->成功解壓
實(shí)現(xiàn)過(guò)程
1. 生成字典
生成密碼字典其實(shí)就是一個(gè)字符組合的過(guò)程。小伙伴們可別用列表去組合噢,很容易就內(nèi)存溢出了,用生成器就最好啦。這里我選擇使用python的 itertools 模塊。 itertools
是2.3版本加入的用于創(chuàng)建循環(huán)用迭代器的函數(shù)模塊。
而
itertools.product(*iterables[, repeat]) 函數(shù)是 對(duì)應(yīng)有序的重復(fù)抽樣過(guò)程
。
寫出來(lái)生成密碼字典的方法:(輸出1,2組成長(zhǎng)度為4的所有密碼)
import itertools
def allkeyword(dic,num):
allkey1 = itertools.product(dic,repeat=num)
allkey2 = (''.join(i) for i in allkey1)
return allkey2
dictionaries = ['1', '2']
print(list(allkeyword(dictionaries,4)))
# ['1111', '1112', '1121', '1122', '1211', '1212', '1221', '1222', '2111', '2112', '2121', '2122', '2211', '2212', '2221', '2222']
2. 解壓文件
好家伙,python的 zipfile
模塊不就可以對(duì)文件壓縮解壓嘛?使用方法參考官方文檔:https://docs.python.org/zh-cn/2/library/zipfile.html
import zipfile
try:
ZIPFILE = zipfile.ZipFile(r'D:\123\1.zip') # 注意路徑
ZIPFILE.extractall(path=r'D:\123',pwd=b'1234') # 解壓到哪個(gè)路徑
print("解壓成功")
except:
print("解壓失敗")
沒(méi)有意外測(cè)試文件應(yīng)該可以解壓成功的。
3. 模擬項(xiàng)目所需加密的壓縮文件
新建abc.txt文件,輸入abc
右鍵txt文件,添加到壓縮文件,并設(shè)置密碼,確定
這里我們刪除原有的txt文件,方便測(cè)試,破解成功后解壓到當(dāng)前路徑
4. 使用生成的字典去爆破密碼
結(jié)合1和2步驟,完整的代碼:( 注意看注釋學(xué)習(xí) )
import zipfile
import itertools
# 破解一個(gè)4位數(shù)密碼數(shù)字和字母為23ab大概5-10分鐘,僅供參考。
dictionaries = ['1', '2', '3', '4','5','6','7','8','9','0',
'a','b','c','d','e','f','g','h','i','j','k',
'l','m','n','o','p','q','r','s','t','u','v',
'w','x','y','z'] #組成破解字典的關(guān)鍵字符(可以按照自己需求添加)
end_for = True # 用于破解成功后,停止循環(huán)的變量
# 設(shè)置密碼的長(zhǎng)度1到16位密碼
for x in range (1,17):
if end_for:
def allkeyword():
allkey1 = itertools.product(dictionaries,repeat=x)
allkey2 = (''.join(i) for i in allkey1)
return allkey2
def trypassword (password):
try:
ZIPFILE = zipfile.ZipFile(r'D:\zip\abc.zip') # 需要解壓帶有密碼的本地abc.zip
ZIPFILE.extractall(path=r'D:\zip',pwd=password.encode('utf-8')) # 解壓到哪個(gè)路徑下
print(f"解壓成功,正確密碼為:{password}") # 解壓成功,并打印出正確密碼
global end_for # 聲明為全局變量,沒(méi)有聲明,重新賦值無(wú)效
end_for = False # 解壓成功,停止循環(huán)
return True
except:
print(f"解壓失敗,嘗試密碼為:{password}")
return False
#用trypassword函數(shù)返回的True或者Flase來(lái)判定程序是否終止。
for pwd in allkeyword() :
if trypassword(pwd):
break
執(zhí)行代碼后,4位數(shù)的密碼(數(shù)字字母組合的)大概5-10分鐘就能成功解壓,破解打印密碼了。
破解密碼后,由于我們?cè)O(shè)置的是解壓到當(dāng)前路徑下,可以看到abc.txt文件就出來(lái)了。
到此這篇關(guān)于使用 Python 破解壓縮文件的密碼的思路詳解的文章就介紹到這了,更多相關(guān)Python破解壓縮文件密碼內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- Python3壓縮和解壓縮實(shí)現(xiàn)代碼
- python解壓zip包中文亂碼解決方法
- Python在后臺(tái)自動(dòng)解壓各種壓縮文件的實(shí)現(xiàn)方法
- python 實(shí)現(xiàn)壓縮和解壓縮的示例
- Python實(shí)現(xiàn)加密的RAR文件解壓的方法(密碼已知)
- Python實(shí)現(xiàn)文件壓縮和解壓的示例代碼
- Python腳本破解壓縮文件口令實(shí)例教程(zipfile)
- 文件上傳服務(wù)器-jupyter 中python解壓及壓縮方式
- Python解壓 rar、zip、tar文件的方法
- python批量解壓zip文件的方法
- 用python批量解壓帶密碼的壓縮包