python暴力破解压缩包密码(python暴力破解zip压缩包)

ゞ 浴缸里的玫瑰 2024-03-27 12:10 185阅读 0赞

python暴力破解压缩包密码

简介

简介
ZIP文件格式是一种数据压缩和文档储存的文件格式,原名Deflate,发明者为菲尔·卡茨(Phil Katz),他于1989年1月公布了该格式的资料。ZIP通常使用后缀名“.zip”,它的MIME格式为application/zip。当前,ZIP格式属于几种主流的压缩格式之一,其竞争者包括RAR格式以及开放源码的7z格式。从性能上比较,RAR及7z格式较ZIP格式压缩率较高,而7-Zip由于提供了免费的压缩工具而逐渐在更多的领域得到应用。Microsoft从Windows ME操作系统开始内置对zip格式的支持,即使用户的计算机上没有安装解压缩软件,也能打开和制作zip格式的压缩文件,OS X和流行的Linux操作系统也对zip格式提供了类似的支持。因此如果在网络上传播和分发文件,zip格式往往是最常用的选择。

ZIP是一种相当简单的分别压缩每个文件的存档格式。分别压缩文件允许不必读取另外的数据而检索独立的文件;理论上,这种格式允许对不同的文件使用不同的算法。不管用何种方法,对这种格式的一个告诫是对于包含很多小文件的时候,存档会明显的比压缩成一个独立的文件(在类Unix系统中一个经典的例子是普通的tar.gz存档是由一个使用gzip压缩的TAR存档组成)要大。

编码讲解

准备工作

首先是需要创建一个.zip后缀名的压缩包,然后给这个zip压缩包设置一个密码。

在这里插入图片描述
注意这里要点击ZIP传统加密。
在这里插入图片描述

在这里插入图片描述

把这个文件放入到pycharm里面。
在这里插入图片描述

开始编码

  • 首先是获取文件后缀名

    from zipfile import ZipFile
    import os

    def passwd(path):

    1. # 获取文件的后缀名
    2. suffix_name = os.path.splitext(path)[-1][1:]
    3. print(suffix_name)

    if name == ‘main‘:

    1. passwd("D:\系统默认\桌面\python数据分析\python爬虫\zip\二叉树.zip")

运行结果
在这里插入图片描述

  • 没有密码的解压方法

    from zipfile import ZipFile
    import os

    def passwd(path):

    1. # 获取文件的后缀名
    2. suffix_name = os.path.splitext(path)[-1][1:]
    3. # print(suffix_name)
    4. # 如果是zip文件
    5. if suffix_name == 'zip':
    6. # 开始读zip文件
    7. with ZipFile(path, 'r') as zip:
    8. # 解压到指定文件目录下
    9. zip.extractall("D:\系统默认\桌面\python数据分析\python爬虫\\target")

    if name == ‘main‘:

    1. passwd("D:\系统默认\桌面\python数据分析\python爬虫\zip\二叉树.zip")

运行结果
对于没有密码的解压,我们写到这一步就可以了,如果设置了有密码,然后了我们就会发现,这个会报错。
在这里插入图片描述

  • 编写枚举密码的函数
    如果学过算法的就知道了,这个就是算法里面的,那个排列组合题,在java和c++里面,需要自己去写,而且这个时间复杂度还很高,在python立面别人已经帮忙做好了这个功能。

    def create_pwd(words):

    1. # 通过导入这包来设置枚举序列
    2. import itertools as its
    3. # 设置基础需要枚举的字符集
    4. # 这个base的意思就是把words集合的字符取repeat次组合
    5. # 打印出来
    6. base = its.product(words, repeat=2)
    7. for i in base:
    8. print(''.join(i))

运行结果
在这里插入图片描述

  • 用暴力破解来破解程序
    其实我们学过算法就知道,其实只要稍微密码长度长一点,基本上就不能够被破解了,除非需要涉及到哈希字典,这个我们以后再讨论,现在就只讨论暴力破解的写法。

完整代码

  1. from zipfile import ZipFile
  2. import os
  3. def passwd(path, pwd):
  4. # 获取文件的后缀名
  5. suffix_name = os.path.splitext(path)[-1][1:]
  6. # print(suffix_name)
  7. # 如果是zip文件
  8. if suffix_name == 'zip':
  9. # 开始读zip文件
  10. with ZipFile(path, 'r') as zip:
  11. # print("当前尝试的密码是:%s"%(pwd))
  12. # 解压到指定文件目录下
  13. try:
  14. # print(pwd.encode('utf-8'))
  15. zip.extractall("D:\系统默认\桌面\python数据分析\python爬虫\\target", pwd=pwd.encode('utf-8'))
  16. print("解压成功,密码是:%s"%(pwd))
  17. return True
  18. except Exception as e: # 添加一个异常处理
  19. pass
  20. def create_pwd(words):
  21. # 通过导入这包来设置枚举序列
  22. import itertools as its
  23. # 设置基础需要枚举的字符集
  24. # 这个base的意思就是把words集合的字符取repeat次组合
  25. # 打印出来
  26. base = its.product(words, repeat=6)
  27. # 一般需要把这个打印函数注释 因为这个函数运行很消耗时间的
  28. for i in base:
  29. # print(''.join(i))
  30. yield ''.join(i) # 把这个函数制作成一个迭代器
  31. if __name__ == '__main__':
  32. words = '123456789'
  33. dir = 'D:\系统默认\桌面\python数据分析\python爬虫\zip\二叉树.zip'
  34. for p in create_pwd(words):
  35. flag = passwd(dir, p)
  36. if flag == True:
  37. break

运行结果
这个结果的命名很奇怪,但是问题不大只要可以解压,后面会讲解一下,比较难的解压方法,涉及到算法。
在这里插入图片描述

在这里插入图片描述

发表评论

表情:
评论列表 (有 0 条评论,185人围观)

还没有评论,来说两句吧...

相关阅读

    相关 暴力破解带有密码压缩文件

    一 暴力破解,就是不断生成新的密码去尝试能否破解成功。假如我们的密码位数为3位,其里面的值有可能是0或者1,其产生的密码集的数量为2的3次幂,也就是八个,然后一个一个去破解。而

    相关 JMeter暴力破解账户密码

    小编软件测试刚入行二个月 为了前途 前几天看了下有关验证码找回密码的安全漏洞的文章,于是做了以下有关暴力破解验证码的总结 周所周知,所谓暴力破解,也就是我们所说的穷举法