Python基础之破解加密压缩包

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: Python基础之破解加密压缩包

在日常工作生活中,经常用到压缩文件,有些为了安全保密,还专门设置了密码,如果忘记密码要怎么破,这时暴力破解就派上了用场,本文以一个简单的小例子,简述如何通过Python中的zipfile模块进行破解,仅供学习分享使用,如有不足之处,还请指正。

准备工作

在本例中,首先准备一个带密码的zip压缩包,采用winrar进行压缩,如下所示:

设置zip文件密码,如下所示:

注意:一定要采用zip传统加密,否则python的zipfile模块将无法解压成功。

破解步骤

1. 下载密码字典

本例采用密码字典+多线程方式进行破解,首先需要下载密码字典,密码字典包含常用的密码,有多个文件,所有需要采用多线程方式,以提高破解效率。密码字典格式如下:

2. 导入模块文件

需要导入zipfile模块,及多线程相关和文件目录相关模块,如下所示:

import zipfile
import time
import threading
import os.path
import os

3. 单个密码解压函数

通过zipfile对象的extractall可以进行解压,解压成功,则停止;否则,继续。如下所示:

def extract(self, file, password):
        try:
            self.threadLock.acquire()
            if self.is_running:
                # password = str(password)
                zfile = zipfile.ZipFile(file, mode='r')
                zfile.extractall(path=".", pwd=password.encode(encoding='utf-8'))
                print("the password is {}".format(password))
                end_time = time.time()
                print('the end time is {}'.format(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(time.time()))))
                print("spend time is {}".format(end_time - self.start_time))
                # 成功解压其余线程终止
                self.is_running = False
                zfile.close()
        except Exception as e:
            print('尝试密码:{},不对'.format(password))
            # print(e)
        finally:
            self.threadLock.release()

4. 遍历单个密码字典文件

遍历单个密码字典文件,并调用解压函数进行解压,如下所示:

def single_pwd_file(self, root, pwd_file):
        """单个密码本破解"""
        file = os.path.abspath("django.zip")
        print(file)
        pwd_file = os.path.abspath(os.path.join(root, pwd_file))
        print("遍历{}文件".format(pwd_file))
        try:
            with open(pwd_file, mode='r', encoding='utf-8') as f:
                pwd = f.readline()
                while pwd:
                    if self.is_running:
                        self.extract(file, pwd.strip())
                    else:
                        break
                    pwd = f.readline()
        except Exception as e:
            pass

5. 遍历所有密码字典文件

遍历所有密码字典文件,每一个字典文件,采用一个线程,如下所示:

def start(self):
        """通过密码本破解"""
        self.start_time = time.time()
        print('the start time is {}'.format(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime(time.time()))))
        root = r"wpa2pojiezidian"
        for root, dirs, files in os.walk(root, topdown=True):
            for pwd_file in files:
                if pwd_file.endswith('.txt') or pwd_file.endswith('.TXT'):
                    if self.is_running:
                        t = threading.Thread(target=self.single_pwd_file, args=(root, pwd_file,))
                        t.start()
                        # t.join()
                    else:
                        break

破解示例

本例为了测试,采用的密码比较简单,所以破解比较快,如下所示:

源码下载链接

为何一定要勾选传统加密?

默认情况下,WinRAR在CTR模式下使用AES-256加密ZIP存档。虽然AES-256比ZIP 2.0传统加密算法安全得多,但它可能与一些较旧的解压软件不兼容。如果需要与这些工具兼容,可以在密码对话框中启用“ZIP传统加密”选项,或在命令行模式下使用-mezl开关。              

Python标准库中的zipfile模块仅支持CRC32加密的zip文件。

一定能暴力破解吗?

采用密码字典文件的方式进行破解,密码字典只是收录了常规的密码,如果加密密码正好不在密码字典文件中,则无法破解。暴力破解,通俗的讲就是逐个密码取尝试,有可能需要破解几天,甚至更长时间,才可能会成功。所以技术理论上可行,但实际上可行性并不高。

备注

苏幕遮·燎沉香

【作者】周邦彦【朝代】宋

燎沉香,消溽暑。鸟雀呼晴,侵晓窥檐语。叶上初阳干宿雨、水面清圆,一一风荷举。

故乡遥,何日去。家住吴门,久作长安旅。五月渔郎相忆否。小楫轻舟,梦入芙蓉浦。

相关文章
|
3天前
|
存储 人工智能 运维
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
|
2月前
|
开发者 Python
如何在Python中管理模块和包的依赖关系?
在实际开发中,通常会结合多种方法来管理模块和包的依赖关系,以确保项目的顺利进行和可维护性。同时,要及时更新和解决依赖冲突等问题,以保证代码的稳定性和可靠性
65 4
|
2月前
|
测试技术 Python
手动解决Python模块和包依赖冲突的具体步骤是什么?
需要注意的是,手动解决依赖冲突可能需要一定的时间和经验,并且需要谨慎操作,避免引入新的问题。在实际操作中,还可以结合使用其他方法,如虚拟环境等,来更好地管理和解决依赖冲突😉。
|
2月前
|
持续交付 Python
如何在Python中自动解决模块和包的依赖冲突?
完全自动解决所有依赖冲突可能并不总是可行,特别是在复杂的项目中。有时候仍然需要人工干预和判断。自动解决的方法主要是提供辅助和便捷,但不能完全替代人工的分析和决策😉。
|
4天前
|
程序员 Linux Python
python中模板和包的使用
本文介绍了 Python 模块和包的基本概念及使用方法。模块是 Python 程序结构的核心,每个以 `.py` 结尾的源文件都是一个模块,包含可重用的代码。文章详细讲解了模块的导入方式(如 `import` 和 `from...import`),模块的搜索顺序,以及如何创建和发布自己的模块。此外,还介绍了包的概念,包是包含多个模块的特殊目录,并通过 `__init__.py` 文件定义对外提供的模块列表。最后,文章简述了如何使用 `pip` 工具管理第三方模块的安装与卸载。作者:大石头的笔记;来源:稀土掘金。
|
1月前
|
Python 容器
[oeasy]python048_用变量赋值_连等赋值_解包赋值_unpack_assignment _
本文介绍了Python中变量赋值的不同方式,包括使用字面量和另一个变量进行赋值。通过`id()`函数展示了变量在内存中的唯一地址,并探讨了变量、模块、函数及类类型的地址特性。文章还讲解了连等赋值和解包赋值的概念,以及如何查看已声明的变量。最后总结了所有对象(如变量、模块、函数、类)都有其类型且在内存中有唯一的引用地址,构成了Python系统的基石。
31 5
|
2月前
|
Python
Python的模块和包
总之,模块和包是 Python 编程中非常重要的概念,掌握它们可以帮助我们更好地组织和管理代码,提高开发效率和代码质量
51 5
|
2月前
|
数据可视化 Python
如何在Python中解决模块和包的依赖冲突?
解决模块和包的依赖冲突需要综合运用多种方法,并且需要团队成员的共同努力和协作。通过合理的管理和解决冲突,可以提高项目的稳定性和可扩展性
|
3月前
|
安全 Linux 数据安全/隐私保护
python知识点100篇系列(15)-加密python源代码为pyd文件
【10月更文挑战第5天】为了保护Python源码不被查看,可将其编译成二进制文件(Windows下为.pyd,Linux下为.so)。以Python3.8为例,通过Cython工具,先写好Python代码并加入`# cython: language_level=3`指令,安装easycython库后,使用`easycython *.py`命令编译源文件,最终生成.pyd文件供直接导入使用。
106 3
python知识点100篇系列(15)-加密python源代码为pyd文件
|
3月前
|
数据安全/隐私保护 Python
Zipfile学习笔记(二)::通过zipfile模块暴力破解加密的压缩文件
如何使用Python的zipfile模块生成密码表并尝试暴力破解加密的ZIP压缩文件。
62 1
Zipfile学习笔记(二)::通过zipfile模块暴力破解加密的压缩文件