用 Python 破解了同學(xué)壓縮文件的密碼
↑↑↑關(guān)注后"星標(biāo)"簡說Python 人人都可以簡單入門Python、爬蟲、數(shù)據(jù)分析 簡說Python推薦 作者:blank# 來源:https://blog.csdn.net/weixin_39098318/article/details/10498083
經(jīng)常遇到百度網(wǎng)盤的壓縮文件加密了,今天我們就破解它!
實(shí)現(xiàn)思路
爆破密碼的思路其實(shí)都大同小異:無非就是字典爆破,就看你是有現(xiàn)成密碼字典,還是自己生成密碼字典,然后進(jìn)行循環(huán)輸入密碼,直到輸入正確位置。現(xiàn)在很多都有防爆破限制,根本無法進(jìn)行暴力破解,但是似乎zip這種大家都是用比較簡單的密碼而且沒有什么限制。
因此 實(shí)現(xiàn)思路就是 生成字典->輸入密碼->成功解壓
實(shí)現(xiàn)過程
1. 生成字典
生成密碼字典其實(shí)就是一個字符組合的過程。小伙伴們可別用列表去組合噢,很容易就內(nèi)存溢出了,用生成器就最好啦。這里我選擇使用python的itertools模塊。itertools是2.3版本加入的用于創(chuàng)建循環(huán)用迭代器的函數(shù)模塊。
而 itertools.product(*iterables[, repeat]) 函數(shù)是對應(yīng)有序的重復(fù)抽樣過程。
寫出來生成密碼字典的方法:(輸出1,2組成長度為4的所有密碼)
import itertoolsdef allkeyword(dic,num):allkey1 = itertools.product(dic,repeat=num)allkey2 = (''.join(i) for i in allkey1)return allkey2dictionaries = ['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 模塊不就可以對文件壓縮解壓嘛?使用方法參考官方文檔:
https://docs.python.org/3/library/zipfile.html

import zipfiletry:ZIPFILE = zipfile.ZipFile(r'D:\123\1.zip') # 注意路徑ZIPFILE.extractall(path=r'D:\123',pwd=b'1234') # 解壓到哪個路徑print("解壓成功")except:print("解壓失敗")
沒有意外測試文件應(yīng)該可以解壓成功的。
3. 模擬項(xiàng)目所需加密的壓縮文件
新建abc.txt文件,輸入abc
右鍵txt文件,添加到壓縮文件,并設(shè)置密碼,確定
這里我們刪除原有的txt文件,方便測試,破解成功后解壓到當(dāng)前路徑
4. 使用生成的字典去爆破密碼
結(jié)合1和2步驟,完整的代碼:(注意看注釋學(xué)習(xí))
import zipfileimport itertools# 破解一個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è)置密碼的長度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 allkey2def trypassword (password):try:ZIPFILE = zipfile.ZipFile(r'D:\zip\abc.zip') # 需要解壓帶有密碼的本地abc.zipZIPFILE.extractall(path=r'D:\zip',pwd=password.encode('utf-8')) # 解壓到哪個路徑下print(f"解壓成功,正確密碼為:{password}") # 解壓成功,并打印出正確密碼global end_for # 聲明為全局變量,沒有聲明,重新賦值無效end_for = False # 解壓成功,停止循環(huán)return Trueexcept:print(f"解壓失敗,嘗試密碼為:{password}")return False#用trypassword函數(shù)返回的True或者Flase來判定程序是否終止。for pwd in allkeyword() :if trypassword(pwd):break
執(zhí)行代碼后,4位數(shù)的密碼(數(shù)字字母組合的)大概5-10分鐘就能成功解壓,破解打印密碼了。
破解密碼后,由于我們設(shè)置的是解壓到當(dāng)前路徑下,可以看到abc.txt文件就出來了。
【讀者福利】
掃下方二維碼添加我的私人微信,可以在我的朋友圈獲取最新的Python學(xué)習(xí)資料,以及近期推文中的源碼或者其他資源,另外不定期開放學(xué)習(xí)交流群,以及朋友圈福利(送書、紅包、學(xué)習(xí)資源等)。 掃碼查看我朋友圈
獲取最新學(xué)習(xí)資源
推薦大家關(guān)注兩個公號
分享程序員生活、互聯(lián)網(wǎng)資訊、理財復(fù)盤日記等 專注于Java學(xué)習(xí)分享,從零和你一起學(xué)Java 關(guān)注后回復(fù)【1024】 送上獨(dú)家資料 ◆◆◆ 歡迎大家圍觀朋友圈,我的微信:pythonbrief 學(xué)習(xí)更多: 整理了我開始分享學(xué)習(xí)筆記到現(xiàn)在超過250篇優(yōu)質(zhì)文章,涵蓋數(shù)據(jù)分析、爬蟲、機(jī)器學(xué)習(xí)等方面,別再說不知道該從哪開始,實(shí)戰(zhàn)哪里找了 “點(diǎn)贊”傳統(tǒng)美德不能丟


