python高危漏洞(Python黑客入门暴力破解zip)
python高危漏洞(Python黑客入门暴力破解zip)
2024-06-29 03:58:27  作者:伱噓偽潒征  网址:https://m.xinb2b.cn/tech/eab228722.html

python高危漏洞(Python黑客入门暴力破解zip)(1)

照顾没有接触过Python编程的同学,行文可能会有些啰嗦。

当然对于那些没有接触过Python的同学小编这里准备了一份Python学习资料,希望对你们有帮助,还有一份Python黑客入门教程你都是可以私信小编“01”获取到的!

python高危漏洞(Python黑客入门暴力破解zip)(2)

废话少说,我们进入正题。

2.1 准备基本材料

在/home/ziptest/目录下,我创建了两个文件,一个test.zip,是一个设置了密码的zip包,密码为456789。

python高危漏洞(Python黑客入门暴力破解zip)(3)

dict.txt文件是一个字典文件,简单的配置了几个密码。

python高危漏洞(Python黑客入门暴力破解zip)(4)

下面我们打开开发工具,开始编写测试代码。

python高危漏洞(Python黑客入门暴力破解zip)(5)

2.2 ZIPFILE

在python中操作zip文件,最简单的方式就是使用zipfile模块,使用该模块可以用来判断一个文件是否是压缩文件,创建、解压文件,获取zip文件的元数据信息。可以使用python的help方法查看该模块的使用方法。

python高危漏洞(Python黑客入门暴力破解zip)(6)

python高危漏洞(Python黑客入门暴力破解zip)(7)

这里我们首先关注下ZipFile类。

python高危漏洞(Python黑客入门暴力破解zip)(8)

该类用来打开,读取,修改,解压zip文件。我们想要操作一个zip文件,第一步就是初始化ZipFile实例。下面我们打开我们准备好的text.zip文件。

import zipfile

zFile = zipfile.ZipFile("/HOME/TEST.ZIP");

我们只传了一个路径参数进去,从帮助文档我们可以看到,后面三个参数都有默认值,这里我们使用默认值就够了。

下面我们关注下ZipFile类的extractall方法。

python高危漏洞(Python黑客入门暴力破解zip)(9)

extractall方法,是把压缩包里面的内容都解压出来,三个参数,path是解压的路径,members是需要解压出来的文件,pwd是密码。

现在我们可以测试下文件解压了。

import zipfile

zFile = zipfile.ZipFile("/HOME/ZIPTEST/TEST.ZIP");

zFile.extractall("/HOME/",pwd="456789");

运行这个脚本。

python高危漏洞(Python黑客入门暴力破解zip)(10)

密码正确的话,会正常解压文件。如果密码不正确会出现什么情况呢?我们在代码中输入一个错误的密码。

import zipfile

zFile = zipfile.ZipFile("/HOME/ZIPTEST/TEST.ZIP");

zFile.extractall(path="/HOME/ZIPTEST",pwd="4567890");

结果如下:

python高危漏洞(Python黑客入门暴力破解zip)(11)

程序会抛出“bad password”的异常。

我们可以通过捕获异常,测试多个密码。

2.3 读取字典文件

在Python中打开文件,使用open方法,这是一个内置方法,查看open的帮助文档,可以看到该方法的参数说明。

python高危漏洞(Python黑客入门暴力破解zip)(12)

open方法返回一个file对象,利用file对象,我们可以读取文件的具体内容。下面我们在代码中测试一下。

import zipfile

passFile = open('/HOME/ZIPTEST/DICT.TXT');

for line in passFile.readlines():

password = line.strip('\N');

print(password);

运行结果如下:

python高危漏洞(Python黑客入门暴力破解zip)(13)

下面我们利用读取到的密码来暴力测试zip文件。

import zipfile

zFile = zipfile.ZipFile("/HOME/ZIPTEST/TEST.ZIP");

passFile = open('/HOME/ZIPTEST/DICT.TXT');

for line in passFile.readlines():

password = line.strip('\N');

try:

zFile.extractall(path="/HOME/ZIPTEST",pwd=password);

print("PASSWORD IS:" password);

exit(0);

except:

pass;

在上面的代码中,我们使用try—except进行异常捕获,密码不正确的时候,程序跳过继续执行。密码正确的时候打印密码,终止程序。运行结果如下:

python高危漏洞(Python黑客入门暴力破解zip)(14)

到目前为止,我们的脚本已经具备了暴力破解zip文件的功能,大家可以看到只有十几行的代码。下面我们为了提升程序的可用性,重构一下这个脚本,利用函数划分功能。

2.4 重构,用函数划分功能

首先定义一个extractFile函数,该函数接收三个参数,一个zipfile对象,解压的目标路径,密码,如果解密成功则返回密码。

def extractFile(toPath,zFile,password):

try:

zFile.extractall(path=toPath,pwd=password);

return password;

except Exception,e:

return;

下面我们再声明一个main方法。

def main():

zFile = zipfile.ZipFile("/HOME/ZIPTEST/TEST.ZIP");

passFile = open('/HOME/ZIP/TEST/DICT.TXT');

for line in passFile.readlines():

password = line.strip('\N');

guess = extractFile("/HOME/",zFile,password);

if guess:

print('SCUCESS' password);

exit(0);

在main方法中,首先初始化了zipfile对象,然后打开字典文件,循环读取密码,传给extractFile方法调用。

分离 了两个方法之后,我们需要在程序的入口处调用main方法,完整代码如下:

import zipfile

def extractFile(toPath,zFile,password):

try:

zFile.extractall(path=toPath,pwd=password);

print('SCUCESS' password);

return password;

except Exception,e:

return;

def main():

zFile = zipfile.ZipFile("/HOME/ZIPTEST/TEST.ZIP");

passFile = open('/HOME/ZIPTEST/DICT.TXT');

for line in passFile.readlines():

password = line.strip('\N');

guess = extractFile("/HOME/",zFile,password);

if guess:

print('SCUCESS' password);

exit(0);

if __name__=='__MAIN__':

main();

这样一来,代码清晰了很多,但是我们更换zip文件和字典文件的时候,还是需要修改代码,很不方便,正常的程序都应该可以传递参数的,ok,下面我们引入optparse库。

2.5 OPTPARSE

Python 有两个内建的模块用于处理命令行参数:

一个是 getopt,《Deep in python》一书中也有提到,只能简单处理 命令行参数;

另一个是 optparse,它功能强大,而且易于使用,可以方便地生成标准的、符合Unix/Posix规范的命令行说明。

首先先引入optparse模块,然后强制添加两个参数,zip文件名和字典文件名。先看代码:

def main():

parser = optparse.OptionParser("usage%prog " \

"-f <zipfile> -d <dictFile>");

parser.add_option('-f',dest='zname',type='string',help='specify zip file');

parser.add_option('-d',dest='dname',type='string',help='specify dict file');

(options,args)=parser.parse_args();

if(options.zname==None)|(options.dname==None):

print parse.usage;

exixt(0);

else:

zname=options.zname;

dname=options.dname;

zFile = zipfile.ZipFile(zname);

passFile = open(dname);

for line in passFile.readlines():

password = line.strip('\n');

guess = extractFile("/home/",zFile,password);

if guess:

print('scucess' password);

exit(0);

首先初始化一个OptionParser对象,然后添加两个选项——“-f”和“-d”。之后在程序运行的时候通过parse_args方法获取输入的参数,如果参数为空,则打印使用方法,退出程序。

下面使用终端来测试这个程序。

无参数情况下:

python高危漏洞(Python黑客入门暴力破解zip)(15)

输入参数:

python高危漏洞(Python黑客入门暴力破解zip)(16)

2.6 小结

这个程序本身并没有什么难点,但是通过这个入门案例,我们可以体验Python编程的基本方法,如何查看帮助文档,如何引入模块,初始化对象,操作zip文件,打开本地文件,命令行参数设置。

  • 红枣功效与作用(红枣功效与作用是什么)
  • 2024-06-29红枣功效与作用是什么红枣,味甘,性温,是补益的佳品红枣中含有丰富的铁元素,铁是合成血红蛋白的必须原料,吃红枣可以补气生血,养血安神,尤其适宜于贫血、睡眠差、神经衰弱、月经后的女性红枣能减轻有毒物质对肝脏的损害,有肝脏方面。
  • 宿迁助力乡村振兴(打造宜居宜业美丽乡村)
  • 2024-06-29打造宜居宜业美丽乡村航拍牛角淹新型农村社区泱波摄中新网宿迁9月8日电(记者刘林)黑铜壶、玉树、绮罗、太阳花锦……中秋前夕,中新网记者走进江苏省宿迁市宿城区耿车镇的多肉产业园,占地3000余亩的产业园内,琳琅满目的多肉植物。
  • 世界五百强管理定律(世界500强都在用的管理方法和工具)
  • 2024-06-29世界500强都在用的管理方法和工具【收藏学习!世界500强都在用的管理方法和工具】二八原则、SWOT分析法、5M因素分析法、PDCA循环规则、WBS任务分解法、OGSM计划法……世界500强都在用的管理方法和工具↓↓教你如何集中资源、。
  • 清朝黄易简介(黄易巅峰大唐双龙传七至十一卷)
  • 2024-06-29黄易巅峰大唐双龙传七至十一卷《大唐双龙传》是黄易的巅峰之作吗,他的巅峰作品都还有哪些?黄易巅峰《大唐双龙传》七到十一卷中,鲁妙子昙花一现,妖女婠婠惊艳登场,比“美人儿场主”商秀珣还抢镜,双龙奇遇不断,武功突飞猛进,跋锋寒加入大唐。
  • 威海大樱桃最新消息(威海环翠区樱桃大棚内樱桃花竞相绽放)
  • 2024-06-29威海环翠区樱桃大棚内樱桃花竞相绽放齐鲁网·闪电新闻2月11日讯春暖花开时节,威海环翠区里口山福德庄村樱桃大棚内的樱桃花竞相绽放,一团团、一簇簇的樱桃花宛如白雪,傲立枝头,不时传来阵阵花香,让人流连忘返樱桃花开压满枝,翘首期盼迎丰收果农。
  • 鹌鹑蛋的保存方法(如何保存鹌鹑蛋)
  • 2024-06-29如何保存鹌鹑蛋有独立的存放空间在没有条件冷藏鹌鹑蛋的时候,要尽量用干净的纸或布做成鹌鹑蛋形状的空穴,使每个鹌鹑蛋有独立的存放空间,并且避免直接暴露在空气里这样可以减少细菌和微生物侵入的机会,能够延长鹌鹑蛋的保存时间。
  • 甜宠娇妻吻上瘾第一部(蜜爱鲜妻一直吻下去)
  • 2024-06-29蜜爱鲜妻一直吻下去宋清樱从顶楼下来后便办理了离职手续楼下大门口,她回头朝楼上望了一眼,看到原本站在窗前的沈安旭迅速拉上了窗帘见状,宋清樱摇摇头,然后便拿着东西离开了沈氏医院,医生再次通知了宋清樱:“宋小姐,如果这周内没。
  • 爱情触手可及露娜与周放(幸福触手可及露娜退出)
  • 2024-06-29幸福触手可及露娜退出《幸福触手可及》由沈阳执导,迪丽热巴、黄景瑜、张馨予、易大千、胡兵、张豆豆、王一鸣、蔡光泰等人主演,是一部典型的都市职场爱情偶像剧最新的剧情中,宋凛用尽了各种办法,但是周放却始终不肯答应复合,让人感到。
  • 漫威系列电影官方观看顺序(漫威电影观看顺序)
  • 2024-06-29漫威电影观看顺序“妇联集结”从2008年《钢铁侠》上映,到2019年《复仇者联盟4:终局之战》,漫威影业一共上映了22部超级英雄电影那么这22部电影的观影顺序是什么?应该从哪部开始看?有的人说按照电影上映时间顺序,有。
  • 画画用铅笔很简单的简笔画(简笔画用数字教你画画)
  • 2024-06-29简笔画用数字教你画画幼儿时期,老师们为了让宝贝们更快速的记住数字,会编一些朗朗上口的数字顺口溜,比如:1像铅笔,会写字;2像鸭子,水中游;3像耳朵,听声音……那么今天,我们暂时先把这种传统的顺口溜放一放,来点新的,也好上。
  • 最差的一款手表(我的手表及对表的一些看法)
  • 2024-06-29我的手表及对表的一些看法说起来从第一次上这个网站也不会很久但是也就着了魔一样不知不觉下了很多块当然了从价格上不会太贵不过毕竟也是自己对表的一些体会和心得由于涉及的表的牌子比较杂也就不在专业的版块发了就在这里发1.第一块是ze。
  • 牛皮鞋怎么保养(保养皮鞋的妙招)
  • 2024-06-29保养皮鞋的妙招一双皮鞋最好隔天穿一次因为皮鞋穿了整日之后汗水会令鞋内产生湿气,所以回家后,应将皮鞋放在阴凉通风处晾干,以防滋生细菌平常穿着皮鞋后,应用鞋布或软毛擦去尘鞋跟与鞋身的隙缝位置,则可用尖头刷子擦除尘垢,然。