手把手教你怎么用Python实现zip文件密码的破解
Python有一个内置模块zipfile可以干这个事情,测试一波,一个测试文件,设置解压密码为123。
importzipfile #创建文件句柄 file=zipfile.ZipFile("测试.zip",'r') #提取压缩文件中的内容,注意密码必须是bytes格式,path表示提取到哪 file.extractall(path='.',pwd='123'.encode('utf-8'))
运行效果如下图所示,提取成功。
好了开始破解老文件的密码,为了提高速度我加了多线程最初的代码:
importzipfile importitertools fromconcurrent.futuresimportThreadPoolExecutor defextract(file,password): ifnotflag:return file.extractall(path='.',pwd=''.join(password).encode('utf-8')) defresult(f): exception=f.exception() ifnotexception: #如果获取不到异常说明破解成功 print('密码为:',f.pwd) globalflag flag=False if__name__=='__main__': #创建一个标志用于判断密码是否破解成功 flag=True #创建一个线程池 pool=ThreadPoolExecutor(100) nums=[str(i)foriinrange(10)] chrs=[chr(i)foriinrange(65,91)] #生成数字+字母的6位数密码 password_lst=itertools.permutations(nums+chrs,6) #创建文件句柄 zfile=zipfile.ZipFile("加密文件.zip",'r') forpwdinpassword_lst: ifnotflag:break f=pool.submit(extract,zfile,pwd) f.pwd=pwd f.pool=pool f.add_done_callback(result)
这个代码有个问题,跑一会儿内存就爆了!原因:ThreadPoolExecutor默认使用的是无界队列,尝试密码的速度跟不上生产密码的速度,会把生产任务无限添加到队列中。导致内存被占满。内存直接飙到95:
然后程序奔溃:
看了一下源码发现ThreadPoolExecutor内部使用的是无界队列,所以导致内存直接飙满,重写ThreadPoolExecutor类中的_work_queue属性,将无界队列改成有界队列,这样就不会出现内存爆满的问题,看代码:
importqueue fromconcurrent.futuresimportThreadPoolExecutor classBoundedThreadPoolExecutor(ThreadPoolExecutor): def__init__(self,max_workers=None,thread_name_prefix=''): super().__init__(max_workers,thread_name_prefix) self._work_queue=queue.Queue(self._max_workers*2)#设置队列大小
最后破解成功,如下图所示。
到此这篇关于手把手教你怎么用Python实现zip文件密码的破解的文章就介绍到这了,更多相关Python破解zip密码内容请搜索本站以前的文章或继续浏览下面的相关文章希望大家以后多多支持本站!
版权声明:本站文章来源标注为YINGSOO的内容版权均为本站所有,欢迎引用、转载,请保持原文完整并注明来源及原文链接。禁止复制或仿造本网站,禁止在非www.yingsoo.com所属的服务器上建立镜像,否则将依法追究法律责任。本站部分内容来源于网友推荐、互联网收集整理而来,仅供学习参考,不代表本站立场,如有内容涉嫌侵权,请联系alex-e#qq.com处理。