爆密碼的思路其實都大同小異:無非就是字典爆破,就看你是有現成密碼字典,還是自己生成密碼字典,然后進行循環輸入密碼,直到輸入正確位置。現在很多都有防爆破限制,根本無法進行暴力破解,但是似乎zip這種大家都是用比較簡單的密碼而且沒有什么限制。
因此 實現思路就是 生成字典->輸入密碼->成功解壓
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)))
import zipfile
import itertools
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'] #組成破解字典的關鍵字符(可以按照自己需求添加)
def allkeyword(): #排列出字符所有4個字符的組合
allkey1 = itertools.product(dictionaries,repeat=4)
allkey2 = (''.join(i) for i in allkey1)
return allkey2
def trypassword (password):
try:
ZIPFILE = zipfile.ZipFile(r'D:\123\1.zip') #定義對象,相當于定義一個壓縮文件1.zip
ZIPFILE.extractall(path=r'D:\12',pwd=password.encode('utf-8'))
print(f"解壓成功,正確密碼為:{password}")
return True
except:
print(f"解壓失敗,嘗試密碼為:{password}")
return False
#用trypassword函數返回的True或者Flase來判定程序是否終止。
for pwd in allkeyword() :
if trypassword(pwd):
break
到此這篇關于Python實現暴力破解有密碼的zip文件的文章就介紹到這了,更多相關Python暴力破解有密碼的zip文件內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!