zip密码暴力破解[单线程]

根据网上一些使用py3破解zip密码的教程,这里记录我实现的几个过程和遇到的问题

问题:

1.zip压缩包,必须是zip老版本的否则无法破解

2.zip密码的格式如果不是ascii的可能会破解失败

3.破解得到密码后,不会自动停止,我已经改进

源码:

import optparse
import zipfile
def extract_zip(zFile,password):
    try:
        #pwd需要的是一个byte类型的 我们需要转换不然是破解不出来密码的
        print("[+][{Pass}] Cracking.....".format(Pass=password));

        zFile.extractall(pwd=password.encode("ascii"));
       #如果解压成功 返回密码 如果失败 就抛出异常
        return password;
    except:
        pass
def main():
    #设置help
    parser = optparse.OptionParser("usage -f <zifFIle> -d <dict>");
    #绑定参数 -f =》zname -d =》dname
    parser.add_option('-f',dest='zname',type='string',help='specify zip file');
    parser.add_option('-d',dest='dname',type='string',help='specify 
  • 1
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
ziperello zip 密码 破解有一种破解方法叫做Known plaintext attack。市面上的密码破解软件几乎都带有这个功能。操作方法就是找到加密压缩包中的任意一个文件,用同样的压缩软件同样的压缩方式压缩成一个不加密的包,然后把这两个压缩包进行比较,这样就能把整个加密的压缩包全部还原成未加密的形式。 原理是这样的:你输入的密码,首先被转换成3个32bit的key,所以可能的key 的组合是2^96,这是个天文数字,如果用暴力穷举的方式是不太可能的,除非你的密码比较短或者有个厉害的字典。压缩软件用这3个key加密所有包中的文件,这也就是说,所有文件的key是一样的,如果我们能够找到这个key,就能解开所有的文件。如果我们找到加密压缩包中的任意一个文件,这个文件和压缩包里的文件是一样的,我们把这个文件用同样的压缩软件同样的压缩方式进行无密码的压缩,得到的文件就是我们的Known plaintext。用这个无密码的压缩包和有密码的压缩包进行比较,分析两个包中相同的那个文件,抽取出两个文件的不同点,就是那3个key了,如此就能得到key。两个相同文件在压缩包中的字节数应该相差12个byte,就是那3个key了。虽然我们还是无法通过这个key还原出密码,但是我们已经可以用这个key解开所有的文件,所以已经满足我的要求了,而且要以前的密码也没什么用呀,我只要文件。 其实很简单,只要你能找到一个相同的文件,就万事大吉了! 所以我用Advanced ZIP Password Recovery(Crack了的)选择Known plaintext attack。用了2分钟就找到了key,然后用了20分钟把我的那个700M的压缩包解开,搞定!
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值