我用Python破解了同事的加密文件,原來他喜歡這個


我用Python破解了同事的加密文件,原來他喜歡這個

​又是一杯奶茶。

事情的經過是這樣的:

我用Python破解了同事的加密文件,原來他喜歡這個

我用Python破解了同事的加密文件,原來他喜歡這個

又是奶茶,行吧快點開工,爭取李大偉回來之前搞定

我用Python破解了同事的加密文件,原來他喜歡這個

這裡還要注意:不管你是剛學Python還是想找python高薪工作,記住:項目開發經驗永遠是核心,如果你沒有python入門到高級實戰視頻教程,可以關注我,後臺私信我 ‘py’ 自動獲取最新python教程資料!還有老司機解答哦!
李大偉說是6位數字密碼

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

<code>#生成從000000到99999的密碼錶
f = open('passdict.txt','w')
for id in range(1000000):
    password = str(id).zfill(6)+'\\n'
    f.write(password)
f.close()
/<code>

這樣,我們就生成了一個從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

<code>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()/<code>

花了不到一分鐘

成功解出密碼是:

我用Python破解了同事的加密文件,原來他喜歡這個

收工√

趁著李大偉還沒回來,

多說兩句。

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

所以本次只要單線程暴力遍歷就ok了。

那如果更多位數,

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

我們可以應用多線程進程解壓,加快速度

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

可以下載用來遍歷

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

大偉回來了。

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

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

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

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

我用Python破解了同事的加密文件,原來他喜歡這個

我用Python破解了同事的加密文件,原來他喜歡這個

不過奶茶真好喝~

  • 相關破解源碼和李大偉壓縮包已上傳Github:https://github.com/zpw1995/aotodata/tree/master/interest/zip
我用Python破解了同事的加密文件,原來他喜歡這個

作者 | 朱小五

又是一杯奶茶。

事情的經過是這樣的:

我用Python破解了同事的加密文件,原來他喜歡這個

我用Python破解了同事的加密文件,原來他喜歡這個

又是奶茶,行吧行吧。

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

李大偉說是6位數字密碼

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

<code>#生成從000000到99999的密碼錶
f = open('passdict.txt','w')
for id in range(1000000):
    password = str(id).zfill(6)+'\\n'
    f.write(password)
f.close()/<code>

這樣,我們就生成了一個從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

<code>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()/<code>

花了不到一分鐘

成功解出密碼是:

我用Python破解了同事的加密文件,原來他喜歡這個

收工√

趁著李大偉還沒回來,

多說兩句。

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

所以本次只要單線程暴力遍歷就ok了。

那如果更多位數,

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

我們可以應用多線程進程解壓,加快速度

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

可以下載用來遍歷

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

大偉回來了。

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

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

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

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

我用Python破解了同事的加密文件,原來他喜歡這個

不過奶茶真好喝~最後注意:不管你是剛學Python還是想找python高薪工作,記住:項目開發經驗永遠是核心,如果你沒有python入門到高級實戰視頻教程,可以關注我,後臺私信我 ‘py’ 自動獲取最新python教程資料!還有老司機解答哦!

本文的文字及圖片來源於網絡加上自己的想法,僅供學習、交流使用,不具有任何商業用途,版權歸原作者所有,如有問題請及時聯繫我們以作處理。


分享到:


相關文章: