一篇文章教你,破解百度网盘加密文件,学会这个举一反二

本文介绍了如何使用Python通过字典生成和暴力破解方法来解密百度网盘中加密的zip压缩文件。首先,通过itertools.product生成可能的密码字典,然后利用zipfile模块尝试解压文件。在实际操作中,创建了一个4位数字和字母的组合字典,并对一个设定有简单密码的压缩文件进行了破解。整个过程展示了从字典生成到解压文件的完整代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

经常遇到百度网盘的压缩文件加密了,今天我们就破解它!

实现思路

爆破密码的思路其实都大同小异:无非就是字典爆破,就看你是有现成密码字典,还是自己生成密码字典,然后进行循环输入密码,直到输入正确位置。现在很多都有防爆破限制,根本无法进行暴力破解,但是似乎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)))
# ['1111', '1112', '1121', '1122', '1211', '1212', '1221', '1222', '2111', '2112', '2121', '2122', '2211', '2212', '2221', '2222']

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:\123',pwd=b'1234')  # 解压到哪个路径
    print("解压成功")

except:
    print("解压失败")

没有意外测试文件应该可以解压成功的。

3.  模拟项目所需加密的压缩文件

图片

新建abc.txt文件,输入abc

图片

右键txt文件,添加到压缩文件,并设置密码,确定

图片

这里我们删除原有的txt文件,方便测试,破解成功后解压到当前路径

4.  使用生成的字典去爆破密码

结合1和2步骤,完整的代码:(注意看注释学习)


import zipfile
import itertools

# 破解一个4位数密码数字和字母为23ab大概5-10分钟,仅供参考。
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']         #组成破解字典的关键字符(可以按照自己需求添加)
end_for = True      # 用于破解成功后,停止循环的变量
# 设置密码的长度1到16位密码
for x in range (1,17):
    if end_for:
        def allkeyword():
            allkey1 = itertools.product(dictionaries,repeat=x)
            allkey2 = (''.join(i) for i in allkey1)
            return allkey2

        def trypassword (password):
            try:
                ZIPFILE = zipfile.ZipFile(r'D:\zip\abc.zip')   # 需要解压带有密码的本地abc.zip
                ZIPFILE.extractall(path=r'D:\zip',pwd=password.encode('utf-8'))     # 解压到哪个路径下
                print(f"解压成功,正确密码为:{password}")       # 解压成功,并打印出正确密码
                global end_for      # 声明为全局变量,没有声明,重新赋值无效
                end_for = False     # 解压成功,停止循环
                return True
            except:
                print(f"解压失败,尝试密码为:{password}")  
                return False

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

图片

执行代码后,4位数的密码(数字字母组合的)大概5-10分钟就能成功解压,破解打印密码了。

图片

破解密码后,由于我们设置的是解压到当前路径下,可以看到abc.txt文件就出来了。

—————END—————

 感谢每一个认真阅读我文章的人,礼尚往来总是要有的:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值