python高危漏洞(Python黑客入门暴力破解zip)
python高危漏洞(Python黑客入门暴力破解zip)
2024-07-01 06:29:26  作者:伱噓偽潒征  网址:https://m.xinb2b.cn/know/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-07-01简述圣诞节的发展及节日特色每年12月25日,是基督徒庆祝耶稣基督诞生的庆祝日,在圣诞节,大部分的天主教教堂都会先在12月24日的耶诞夜,亦即12月25日凌晨举行子夜弥撒,而一些基督教会则会举行报佳音,然后在12月25日庆祝圣诞。
  • 文章姚笛马伊琍离婚没(马伊琍立刻离婚)
  • 2024-07-01马伊琍立刻离婚【作者:叶公子】PS:某些公号,请别抄袭我,我也发公号最近,姚笛被拍到和某富商现身北京某餐厅,用餐结束后,两人牵手在餐厅门口送别友人姚笛全程带笑,和友人握手拥抱,并挨个将好友送上车,看起来心情超赞20。
  • 门泊东吴万里船整首诗词(京口瓜洲一水间)
  • 2024-07-01京口瓜洲一水间今年春,手机上最流行的打油诗之一:不求三月下扬州,但求四月上茶楼何其有幸,我们在二月底驱车下了一次扬州(回家没两天就封控了,到现在……)扬州自古繁华,对她我们都浮想联翩这是一次说走就走的旅行,(你们曾。
  • 2022年离婚都需要什么手续和证件(2022年离婚手续怎么办理)
  • 2024-07-012022年离婚手续怎么办理2022年您如果准备离婚,我现在告诉您怎么办理离婚手续离婚有两种情况:一种是双方就婚姻、孩子抚养、财产分割等能达成一致,可以协议离婚;一种是就婚姻、孩子抚养、财产分割有一项不能达成一致,只能诉讼离婚一。
  • 闭口痘痘和闭口粉刺的区别(令人困扰的闭口和痘痘)
  • 2024-07-01令人困扰的闭口和痘痘对于像我们这么爱美的人,当然不能忍受的就是脸上凹凸不平了,最近很多人都说自己长痘痘,还有一种就是闷在皮肤里面,也不知道是什么,不知道是不是痘痘其实这多半是闭口闭口就是闭合性粉刺,一般呈现为白头粉刺或者。
  • 人类是20万年前一个女性的后代(世上第一个女人诞生之后)
  • 2024-07-01世上第一个女人诞生之后今天我们要讲的,是奥利匹斯神系中人类的起源及“潘多拉魔盒”的故事在远古时期,大地上尚无人类泰坦巨神的后裔普罗米修斯依照自己的相貌,创造了第一批由黏土捏成的男人与普罗米修斯关系和睦的雅典娜,赋予了人类灵。
  • 固特超声波清洗机使用方法(3分钟快速清洁干净)
  • 2024-07-013分钟快速清洁干净作为一个左右眼近视度数都超过800°的高度近视人士,眼镜是我必须随身携带的物品,离开了眼镜,世界就是一片模糊,真正的3米外男女不分,5米之外人畜不分我一直都不喜欢佩戴隐形眼镜,因为佩戴不便,清洁维护也。
  • 日语学习者一定要知道的(日语入门者踩过的坑和走过的花道)
  • 2024-07-01日语入门者踩过的坑和走过的花道如何背单词背单词是一个“长长长长...长的过程“(参见飞飞在奇葩说上说婚礼的那个语气),反复记忆是肯定的以下是一些我认为有用的tips1.之前讲到《标日》的好处的时候漏了一点,就是《标日》的总单词表很。
  • 吃得多但是不长胖是什么原因(怎么吃都不长胖)
  • 2024-07-01怎么吃都不长胖不知道大家身边有没有这样一群人:明明都是在一起胡吃海喝,甚至还吃得比你多,零食也不断,但就是不见他们“长肉”这种胖不起来的体质,总是令不少减肥中的朋友们羡慕不已不过,这是什么原因呢?他们吃下去的食物究。
  • 转生成反派师尊的动漫一口气看完(国漫看什么请和我生娃吧)
  • 2024-07-01国漫看什么请和我生娃吧龙一直以来都是中国古代传说中最为强大的奇幻生物,他们不但是皇权的象征,还是能够呼风唤雨的存在因此在很多作品中,他们的形象大多都十分高大上,令人望而生畏但要是神龙们突然有一天变成了凡人,并且还个个都一心。
  • 激励的人生格言(可以激励的人生的句子)
  • 2024-07-01可以激励的人生的句子今天你是否成功取决于你昨天的态度,今天的态度决定了你明天是否成功觉得自己做的到和不做的到,其实只在一念之间没有了爱的语言,所有的文字都是乏味的每一件事都要用多方面的角度来看它美好的生命应该充满期待、惊。
  • 正确叠衣服的方法省时又省空间(方法其实很简单)
  • 2024-07-01方法其实很简单摘要:现在天气渐渐寒冷,我们的厚衣服也都拿出来穿了,但是大家会发现,我们的厚衣服挂衣柜或者放衣柜,会非常占空间,总感觉衣柜不够用,今天教大家怎么收纳折叠这些厚衣服,不占空间更整洁,一起跟着妙招来看看吧。