您現在的位置是:首頁 > 棋牌

我用 Python 破解了同事的加密壓縮包

  • 由 CSDN 發表于 棋牌
  • 2021-07-03
簡介科普時間:zipFile模組式Python自帶的模組,提供了對zip 檔案的建立,讀,寫,追加,解壓以及列出檔案列表的操作解壓使用extractll方法extractall(path=None, members=None, pwd=None

飛壓zip用什麼解壓

我用 Python 破解了同事的加密壓縮包

作者 | 朱小五

又是一杯奶茶。

事情的經過是這樣的:

我用 Python 破解了同事的加密壓縮包

我用 Python 破解了同事的加密壓縮包

又是奶茶,行吧行吧。

快點開工,爭取李大偉回來之前搞定。

李大偉說是6位數字密碼

那麼我們可以利用python生成全部的六位數字密碼

#生成從000000到99999的密碼錶

f = open(‘passdict。txt’,‘w’)

for id in range(1000000):

password = str(id)。zfill(6)+‘\n’

f。write(password)

f。close

這樣,我們就生成了一個從000000到99999的密碼錶。

並把它們存入到 passdict。txt 的檔案中。

我用 Python 破解了同事的加密壓縮包

6位的密碼錶就這麼大!!!

下一步做什麼?

自然是將生成的密碼錶中的密碼遍歷,

暴力破解啦!

科普時間:

zipFile模組式Python自帶的模組,提供了對zip 檔案的建立,讀,寫,追加,解壓以及列出檔案列表的操作

解壓使用extractll方法extractall(path=None, members=None, pwd=None)

path:指定解壓後文件的位置

members:(可選)指定要Zip檔案中要解壓的檔案,這個檔名稱必須是透過namelist方法返回列表的子集

pwd:指定Zip檔案的解壓密碼

那麼我們可以利用 zipFile 模組來遍歷密碼錶,

挨個挨個密碼嘗試,看能不能開啟壓縮包。

直到成功。

匯入zipFile

import zipfile

def extractFile(zipFile, password):

try:

zipFile。extractall(pwd= bytes(password, “utf8” ))

print(“李大偉的壓縮包密碼是” + password) #破解成功

except:

pass #失敗,就跳過

def main:

zipFile = zipfile。ZipFile(‘李大偉。zip’)

PwdLists = open(‘passdict。txt’) #讀入所有密碼

for line in PwdLists。readlines: #挨個挨個的寫入密碼

Pwd = line。strip(‘\n’)

guess = extractFile(zipFile, Pwd)

if __name__ == ‘__main__’:

main

花了不到一分鐘

成功解出密碼是:

我用 Python 破解了同事的加密壓縮包

收工√

趁著李大偉還沒回來,

多說兩句。

李大偉設定的只是6位數字的密碼,

所以本次只要

單線

程暴力遍歷就ok了。

那如果更多位數,

字母數字特殊字元混合的複雜密碼呢?

我們可以應用多執行緒程序解壓,加快速度

網路上還有一些暴力破解字典,

可以

下載

用來遍歷

感興趣的朋友們不妨試試。

大偉回來了。

我告訴他密碼就是壓縮包當天的日期。

李大偉表示:20191119他已經試過了。

然而這個壓縮包的壓縮時間是前一天20191118啊。

你口口聲聲說用當天日期,拿今天1119試什麼試?

我用 Python 破解了同事的加密壓縮包

不過奶茶真好喝~

相關破解原始碼和李大偉壓縮包已上傳Github:https://github

。com

/zpw1995/aotodata/tree/master/interest/zip

作者:朱小五,網際網路公司資料分析師。熱衷於Python爬蟲,資料分析,視覺化,個人

公眾號

《凹凸玩資料》,有趣的不像個技術號~

【End】

Top