Python實現暴力破解有密碼的zip文件的方法

背景

今天朋友給我發瞭一個某遊戲的兌換碼,壓縮文件發過來的。結果被加密瞭。wc?還說叫爸爸就給我密碼?男人是這麼容易像惡勢力低頭的?直接給你爆瞭好吧,小兔崽子。

一、思路

爆密碼的思路其實都大同小異:無非就是字典爆破,就看你是有現成密碼字典,還是自己生成密碼字典,然後進行循環輸入密碼,直到輸入正確位置。現在很多都有防爆破限制,根本無法進行暴力破解,但是似乎zip這種大傢都是用比較簡單的密碼而且沒有什麼限制。
因此 實現思路就是 生成字典->輸入密碼->成功解壓

二、實現過程

1.生成字典
生成密碼字典其實就是一個字符組合的過程。小夥伴們可別用列表去組合噢,很容易就內存溢出瞭,用生成器就最好啦。這裡我選擇使用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)))

輸出結果:

在這裡插入圖片描述

2.解壓文件
好傢夥,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:\12',pwd=b'1234')
  print("解壓成功")

except:
  print("解壓失敗")

沒有意外測試文件應該可以解壓成功的。

3.使用生成的字典去爆破密碼
結合1、2去修改!直接貼代碼啦:

import zipfile
import itertools


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']     #組成破解字典的關鍵字符(可以按照自己需求添加)


def allkeyword():      #排列出字符所有4個字符的組合
  allkey1 = itertools.product(dictionaries,repeat=4)
  allkey2 = (''.join(i) for i in allkey1)
  return allkey2


def trypassword (password):
  try:
    ZIPFILE = zipfile.ZipFile(r'D:\123\1.zip')  #定義對象,相當於定義一個壓縮文件1.zip
    ZIPFILE.extractall(path=r'D:\12',pwd=password.encode('utf-8')) 
    print(f"解壓成功,正確密碼為:{password}")
    return True
  except:
    print(f"解壓失敗,嘗試密碼為:{password}")
    return False

#用trypassword函數返回的True或者Flase來判定程序是否終止。
for pwd in allkeyword() :  
  if trypassword(pwd):
    break

爆破測試的壓縮文件:

在這裡插入圖片描述

三、結束

好瞭,到這裡這個程序就結束啦。

到此這篇關於Python實現暴力破解有密碼的zip文件的文章就介紹到這瞭,更多相關Python暴力破解有密碼的zip文件內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: