tft每日頭條

 > 職場

 > python源碼加密工具

python源碼加密工具

職場 更新时间:2024-07-24 20:12:55

事情的經過是這樣的:

python源碼加密工具(我用Python破解了同事加密的壓縮包)1

python源碼加密工具(我用Python破解了同事加密的壓縮包)2

又是奶茶,行吧行吧。

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

大偉說是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源碼加密工具(我用Python破解了同事加密的壓縮包)3


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源碼加密工具(我用Python破解了同事加密的壓縮包)4

收工√

趁着大偉還沒回來,

多說兩句。


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

所以本次隻要單線程暴力遍曆就ok了。

那如果更多位數,


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


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


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


可以下載用來遍曆


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


大偉回來了。

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

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

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


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

python源碼加密工具(我用Python破解了同事加密的壓縮包)5

不過奶茶還挺好喝~


,

更多精彩资讯请关注tft每日頭條,我们将持续为您更新最新资讯!

查看全部

相关職場资讯推荐

热门職場资讯推荐

网友关注

Copyright 2023-2024 - www.tftnews.com All Rights Reserved