您好,登錄后才能下訂單哦!
這篇文章主要介紹如何使用Python破解壓縮文件,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
其實都大同小異:無非就是字典爆破,就看你是有現成密碼字典,還是自己生成密碼字典,然后進行循環輸入密碼,直到輸入正確位置。現在很多都有防爆破限制,根本無法進行暴力破解,但是似乎zip這種大家都是用比較簡單的密碼而且沒有什么限制。
因此 實現思路就是
生成字典->輸入密碼->成功解壓
生成密碼字典其實就是一個字符組合的過程。小伙伴們可別用列表去組合噢,很容易就內存溢出了,用生成器就最好啦。這里我選擇使用python的 itertools 模塊。 itertools
是2.3版本加入的用于創建循環用迭代器的函數模塊。
而
itertools.product(*iterables[, repeat]) 函數是 對應有序的重復抽樣過程
。
寫出來生成密碼字典的方法:(輸出1,2組成長度為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']
好家伙,python的 zipfile
模塊不就可以對文件壓縮解壓嘛?使用方法參考官方文檔: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') # 解壓到哪個路徑 print("解壓成功") except: print("解壓失敗")
沒有意外測試文件應該可以解壓成功的。
新建abc.txt文件,輸入abc
右鍵txt文件,添加到壓縮文件,并設置密碼,確定
這里我們刪除原有的txt文件,方便測試,破解成功后解壓到當前路徑
結合1和2步驟,完整的代碼:( 注意看注釋學習 )
import zipfile import itertools # 破解一個4位數密碼數字和字母為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'] #組成破解字典的關鍵字符(可以按照自己需求添加) end_for = True # 用于破解成功后,停止循環的變量 # 設置密碼的長度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')) # 解壓到哪個路徑下 print(f"解壓成功,正確密碼為:{password}") # 解壓成功,并打印出正確密碼 global end_for # 聲明為全局變量,沒有聲明,重新賦值無效 end_for = False # 解壓成功,停止循環 return True except: print(f"解壓失敗,嘗試密碼為:{password}") return False #用trypassword函數返回的True或者Flase來判定程序是否終止。 for pwd in allkeyword() : if trypassword(pwd): break
執行代碼后,4位數的密碼(數字字母組合的)大概5-10分鐘就能成功解壓,破解打印密碼了。
破解密碼后,由于我們設置的是解壓到當前路徑下,可以看到abc.txt文件就出來了。
以上是“如何使用Python破解壓縮文件”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。