Python輕松破解加密壓縮包詳解

相信大傢都遇到過這種情況,下載文件的時候遇到壓縮包又沒有密碼,或者說自己設置的加密密碼,但是忘記瞭,就很難受~

在這裡插入圖片描述

但是~

在Python程序員面前,這都是小問題!

在這裡插入圖片描述

話不多說,我們直接開始操作.。

一、準備工作

我們先打開一個加密的壓縮包嘗試原始方法解壓一下

在這裡插入圖片描述

然後彈出來讓我輸密碼

在這裡插入圖片描述

正常打不開,如果你點擊跳過所有加密,它也不會打開,直接就關閉當前你窗口瞭。

那正常情況下,我們能怎麼辦,什麼也辦不瞭,下一個會更乖。

在這裡插入圖片描述

我們打開pycharm,新建一個py文件,暫且我把它命名為zip_pwd

靈魂三問:沒有pycharm?Python也沒有?還不會安裝?私我

在這裡插入圖片描述

在這之前呢,我們先要去收集一些信息,比如當前的密碼位數與類型。

類型包含包括它有沒有特殊字符,有沒有字符串,是不是純數字。

假設我們現在已知信息呢,總共有兩個,已知當前密碼類型為整形,六位數密碼。

我們先創建一個純數字6位密碼庫,你也可以去GitHub上面下載一個包含所有字符的密碼字典庫,這個現在是開源的,破解時間具體要看設置的密碼長短、復雜與否。

在這裡插入圖片描述

二、開始操作

回到正題

已知我們現在的密碼是六位純數字,那麼怎麼自己創建密碼字典呢?

首先我們要完成一個文件寫入的功能

首先聲明一個變量 f

f = open()
# Python內置函數  

open是一個IO流,可以完成文件讀寫功能。

比如說我先想在一個文件裡寫入一些內容,就可以通過open去做 。

然後我們通過open創建一個文件,名字暫且命名為possword.txt,在加入一個寫入方式,以 w方式去寫入。

f = open('password.txt','w')

然後通過循環去創建密碼,密碼設置個1000000

for id in range(1000000)

這時候需要創建一個password變量生成密碼,創建之前先導入一個方法的包。

import zipfile

然後通過password可以開始生成密碼瞭 ,這個zfill等於 6位的,再加上換行,因為生成一個密碼就要換一行,並且生成密碼應該是一個字符串類型。

password = str(id).zfill(6) + '\n'

然後通過f.write方法把password寫入到文件當中

f.write(password)

寫進去之後要去關閉當前的文件流

f.close()

然後我們來嘗試去生成一下,看看能不能成功。

import zipfile

f = open('password.txt','w')
for id in range(1000000)
    password = str(id).zfill(6) + '\n'
    f.write(password)
f.close()

可以看到這裡給我們生成瞭一個possword.txt密碼字典,它是一個密碼庫。

在這裡插入圖片描述

從000000一直到999999它已經全部生成出來瞭。

在這裡插入圖片描述

這就是一個簡單的密碼字典生成方式,如果要去生成一個比較復雜的密碼肯定不會這麼簡單,給你們看個一個復雜的,這裡我就不演示瞭,看看就可以瞭,將近寫瞭一萬多行。

在這裡插入圖片描述

所以你們自己想要去生成的話,還得專門好好學一下。

在這裡插入圖片描述

搞定六位數數字密碼字典後我們需要完成解決壓縮文件密碼的函數

首先我們先來聲明一個函數 ,取個名字叫file,然後加入兩個行參。

第一個是我的壓縮文件zipfile,第二個是當前需要傳入的密碼password

def pwd_file(zipfile,password):

傳完行參後寫上一個異常處理,調用zipfile,它裡面會有一個方法extractall傳入兩個值,第一個是pwd傳入字節,在字節裡傳入行參,編碼集是utf8

tey:
	zipfile.extractall(pwd=bytes(password, 'utf8'))

然後print壓縮包密碼,打印password

print('壓縮包密碼:', password)

因為密碼庫裡面密碼比較多,隻有一個正確的,其它的都是錯誤的,所以肯定會報錯,所以我們要寫一個異常處理,寫上一個pass就可以瞭,報錯瞭就給它pass掉。

except:
    pass

這就是一個簡單的函數,我們通過zipfile它裡面的一個extractall方法去智能的獲取正確密碼,它是可以自動匹配密碼的。

所以說Python牛逼,很多東西都不需要我們去寫,直接調用就好瞭。

在這裡插入圖片描述

然後我們來寫上執行函數

先寫上一個main函數

def main():

main函數裡面,通過zipfile方法把加密的壓縮文件代入到代碼中。

zipFlie = zipfile.ZipFile('./獲取文件密碼.zip')

通過pwd生成一個list變量,打開生成的密碼文件。

pwd_list = open('./password.txt')

然後我們需要一個一個去試密碼,這個是一行一行的去讀。

for line in pwd_list.readlines():

讀到一個就把它寫進去,拿到一個密碼刪除一個換行符。

pwd = line.strip('\n')

通過pwd_file調用之前寫的函數,傳zipFliepwd

pwd_file(zipFlie, pwd)

最後寫入函數入口,寫上一個main,為什麼要寫這個函數入口呢?不寫也可以運行的。

因為它是用來去做測試的。

if __name__是一個測試入口,什麼意思呢?

比如我在當前文件下導入瞭其它文件庫,但是我又不想用,我就可以通過if讓它不去運行,所以可寫可不寫,當一個延伸。

if __name__ == '__main__':
    main()

全部代碼

import zipfile


f = open('password.txt', 'w')
for id in range(1000000):
    password = str(id).zfill(6) + '\n'
    f.write(password)
f.close()


def pwd_file(zipFlie, password):
    try:
        zipFlie.extractall(pwd=bytes(password, 'utf8'))
        print('壓縮包密碼:', password)
    except:
        pass


def main():
    zipFlie = zipfile.ZipFile('./獲取文件密碼.zip')
    pwd_list = open('./password.txt')
    for line in pwd_list.readlines():
        pwd = line.strip('\n')
        pwd_file(zipFlie, pwd)


if __name__ == '__main__':
    main()

我們看看效果,可以看到壓縮包的密碼已經打印出來瞭。

在這裡插入圖片描述

如果你要獲取的密碼越復雜,你的電腦越好就計算的越快。

兄弟們,學廢瞭嗎?

原創不易,點個贊支持一下哇~

在這裡插入圖片描述

到此這篇關於Python輕松破解加密壓縮包詳解的文章就介紹到這瞭,更多相關Python破解加密壓縮包內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: