Python基础之破解加密压缩包

简介: 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文件。

一定能暴力破解吗?

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

备注

苏幕遮·燎沉香

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

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

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

相关文章
|
7天前
|
Python
【Python笔记】pip intall -e命令:让你的工程直接使用开源包的源码,可断点调试,修改源码!
【Python笔记】pip intall -e命令:让你的工程直接使用开源包的源码,可断点调试,修改源码!
9 0
|
15天前
|
Python
python学习14-模块与包
python学习14-模块与包
|
18天前
|
Python
掌握Python导包技艺:揭秘导包语句的奥秘
掌握Python导包技艺:揭秘导包语句的奥秘
19 0
|
18天前
|
存储 算法 安全
Python加密算法有哪些?有什么作用?
这些加密算法的作用在于保护敏感数据的隐私和完整性。它们可以用于数据传输、存储、身份验证和数字签名等领域。通过加密,可以确保数据在传输和存储过程中不被未经授权的人访问或篡改。同时,数字签名可以用于验证数据的来源和完整性,防止数据被篡改或冒充。不同的加密算法在不同的应用场景中起到不同的作用,选择合适的算法取决于安全需求和性能要求。 买CN2云服务器,免备案服务器,高防服务器,就选蓝易云。百度搜索:蓝易云
9 0
|
19天前
|
JavaScript 前端开发 关系型数据库
金融技术解决方案:用Python和Vue开发加密货币交易平台
【4月更文挑战第11天】本文介绍了如何使用Python和Vue.js构建加密货币交易平台。首先确保安装了Python、Node.js、数据库系统和Git。后端可选择Flask或Django框架,通过RESTful API处理交易。前端利用Vue.js、Vuex和Vue Router创建用户友好的界面,并用Axios与后端通信。这种架构促进团队协作,提升代码质量和平台功能。
|
22天前
|
Unix iOS开发 MacOS
「Python系列」Python pip(包管理工具)、Anaconda介绍
Python pip是一个现代的、通用的Python包管理工具,用于查找、下载、安装、卸载Python包。它支持从PyPI(https://pypi.org/)、版本控制、本地项目以及直接从分发文件进行安装。pip是一个命令行程序,安装后,会向系统添加一个pip命令,该命令可以从命令提示符运行。
50 0
|
2月前
|
编解码 测试技术 数据安全/隐私保护
小工具实战-Python实现小工具输出字符串大小写转换、字符串统计、编解码、MD5加密
小工具实战-Python实现小工具输出字符串大小写转换、字符串统计、编解码、MD5加密
43 2
|
2月前
|
分布式计算 DataWorks 关系型数据库
DataWorks常见问题之第三方Python依赖包使用失败如何解决
DataWorks是阿里云提供的一站式大数据开发与管理平台,支持数据集成、数据开发、数据治理等功能;在本汇总中,我们梳理了DataWorks产品在使用过程中经常遇到的问题及解答,以助用户在数据处理和分析工作中提高效率,降低难度。
|
2月前
|
存储 算法 安全
Python的hashlib模块:7种加密算法深入剖析
Python的hashlib模块:7种加密算法深入剖析
155 0
|
2月前
|
网络协议 安全 Linux
Scapy:Python发包收包利器
Scapy:Python发包收包利器
33 0