您好,登錄后才能下訂單哦!
本篇內(nèi)容介紹了“Python如何破解加密壓縮包”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
我們先打開一個加密的壓縮包嘗試原始方法解壓一下
然后彈出來讓我輸密碼
正常打不開,如果你點擊跳過所有加密,它也不會打開,直接就關(guān)閉當(dāng)前你窗口了。
那正常情況下,我們能怎么辦,什么也辦不了,下一個會更乖。
我們打開pycharm
,新建一個py
文件,暫且我把它命名為zip_pwd
靈魂三問:沒有pycharm?Python也沒有?還不會安裝?私我
在這之前呢,我們先要去收集一些信息,比如當(dāng)前的密碼位數(shù)與類型。
類型包含包括它有沒有特殊字符,有沒有字符串,是不是純數(shù)字。
假設(shè)我們現(xiàn)在已知信息呢,總共有兩個,已知當(dāng)前密碼類型為整形,六位數(shù)密碼。
我們先創(chuàng)建一個純數(shù)字6位密碼庫,你也可以去GitHub上面下載一個包含所有字符的密碼字典庫,這個現(xiàn)在是開源的,破解時間具體要看設(shè)置的密碼長短、復(fù)雜與否。
回到正題
已知我們現(xiàn)在的密碼是六位純數(shù)字,那么怎么自己創(chuàng)建密碼字典呢?
首先我們要完成一個文件寫入的功能
首先聲明一個變量 f
f = open() # Python內(nèi)置函數(shù)
open
是一個IO流,可以完成文件讀寫功能。
比如說我先想在一個文件里寫入一些內(nèi)容,就可以通過open
去做 。
然后我們通過open
創(chuàng)建一個文件,名字暫且命名為possword.txt
,在加入一個寫入方式,以 w
方式去寫入。
f = open('password.txt','w')
然后通過循環(huán)去創(chuàng)建密碼,密碼設(shè)置個1000000
for id in range(1000000)
這時候需要創(chuàng)建一個password
變量生成密碼,創(chuàng)建之前先導(dǎo)入一個方法的包。
import zipfile
然后通過password
可以開始生成密碼了 ,這個zfill
等于 6位的,再加上換行,因為生成一個密碼就要換一行,并且生成密碼應(yīng)該是一個字符串類型。
password = str(id).zfill(6) + '\n'
然后通過f.write
方法把password
寫入到文件當(dāng)中
f.write(password)
寫進去之后要去關(guān)閉當(dāng)前的文件流
f.close()
然后我們來嘗試去生成一下,看看能不能成功。
import zipfile f = open('password.txt','w') for id in range(1000000) password = str(id).zfill(6) + '\n' f.write(password) f.close()
可以看到這里給我們生成了一個possword.txt
密碼字典,它是一個密碼庫。
從000000一直到999999它已經(jīng)全部生成出來了。
這就是一個簡單的密碼字典生成方式,如果要去生成一個比較復(fù)雜的密碼肯定不會這么簡單,給你們看個一個復(fù)雜的,這里我就不演示了,看看就可以了,將近寫了一萬多行。
所以你們自己想要去生成的話,還得專門好好學(xué)一下。
搞定六位數(shù)數(shù)字密碼字典后我們需要完成解決壓縮文件密碼的函數(shù)
首先我們先來聲明一個函數(shù) ,取個名字叫file
,然后加入兩個行參。
第一個是我的壓縮文件zipfile
,第二個是當(dāng)前需要傳入的密碼password
def pwd_file(zipfile,password):
傳完行參后寫上一個異常處理,調(diào)用zipfile
,它里面會有一個方法extractall
傳入兩個值,第一個是pwd
傳入字節(jié),在字節(jié)里傳入行參,編碼集是utf8
tey: zipfile.extractall(pwd=bytes(password, 'utf8'))
然后print
壓縮包密碼,打印password
print('壓縮包密碼:', password)
因為密碼庫里面密碼比較多,只有一個正確的,其它的都是錯誤的,所以肯定會報錯,所以我們要寫一個異常處理,寫上一個pass
就可以了,報錯了就給它pass掉。
except: pass
這就是一個簡單的函數(shù),我們通過zipfile它里面的一個extractall方法去智能的獲取正確密碼,它是可以自動匹配密碼的。
然后我們來寫上執(zhí)行函數(shù)
先寫上一個main
函數(shù)
def main():
在main
函數(shù)里面,通過zipfile
方法把加密的壓縮文件代入到代碼中。
zipFlie = zipfile.ZipFile('./獲取文件密碼.zip')
通過pwd
生成一個list
變量,打開生成的密碼文件。
pwd_list = open('./password.txt')
然后我們需要一個一個去試密碼,這個是一行一行的去讀。
for line in pwd_list.readlines():
讀到一個就把它寫進去,拿到一個密碼刪除一個換行符。
pwd = line.strip('\n')
通過pwd_file
調(diào)用之前寫的函數(shù),傳zipFlie
和pwd
pwd_file(zipFlie, pwd)
最后寫入函數(shù)入口,寫上一個main
,為什么要寫這個函數(shù)入口呢?不寫也可以運行的。
因為它是用來去做測試的。
if __name__
是一個測試入口,什么意思呢?
比如我在當(dāng)前文件下導(dǎo)入了其它文件庫,但是我又不想用,我就可以通過if讓它不去運行,所以可寫可不寫,當(dāng)一個延伸。
if __name__ == '__main__': main()
全部代碼
import zipfile f = open('password.txt', 'w') for id in range(1000000): password = str(id).zfill(6) + '\n' f.write(password) f.close() def pwd_file(zipFlie, password): try: zipFlie.extractall(pwd=bytes(password, 'utf8')) print('壓縮包密碼:', password) except: pass def main(): zipFlie = zipfile.ZipFile('./獲取文件密碼.zip') pwd_list = open('./password.txt') for line in pwd_list.readlines(): pwd = line.strip('\n') pwd_file(zipFlie, pwd) if __name__ == '__main__': main()
我們看看效果,可以看到壓縮包的密碼已經(jīng)打印出來了。
如果你要獲取的密碼越復(fù)雜,你的電腦越好就計算的越快。
“Python如何破解加密壓縮包”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。