Python暴力尝试zip压缩包密码

该博客介绍了一种使用Python的multiprocessing库进行并行处理,通过全排列生成可能的密码组合来尝试破解五位字母数字组成的zip压缩包密码的方法。代码中定义了全排列函数和测试压缩包密码的函数,并启动多个进程进行密码尝试,直到找到正确的密码。
摘要由CSDN通过智能技术生成

尝试zip压缩包密码

实测在五位时就很吃力了

import multiprocessing
import zipfile
import time
import os

# 字母数字表
table = [chr(i) for i in range(97, 123)]

num = [chr(i) for i in range(48, 58)]

sum_table = table + num

flag = True


# 全排列
def permutation(n):
    if n == 1:
        return sum_table
    else:
        result = []
        for i in range(len(sum_table)):
            for j in permutation(n-1):
                result.append(sum_table[i] + j)
        return result


pd_table = []

# for i in range(4):
pd_table = permutation(5)


# 测试压缩包密码
def zip_test(zip_name, password):
    try:
        zip_file = zipfile.ZipFile(zip_name, 'r')
        zip_file.extractall(pwd=password.encode())
        print(password)
        global flag
        # 成功解压其余线程终止
        flag = False
    except:
        pass


def zip_test_all(zip_name, list):
    for i in list:
        global flag
        if not flag:
            return
        zip_test(zip_name, i)


if __name__ == '__main__':
    zip_name = 'readme.zip'

    process_list = []
    for i in range(8):
        # 实例化进程对象
        p = multiprocessing.Process(
            target=zip_test_all, args=(zip_name,
                                       pd_table[int(i*len(pd_table)/8):int((i+1)*len(pd_table)/8)],))
        p.start()
        process_list.append(p)

    for i in process_list:
        p.join()

    print('结束')

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值