python高危漏洞(Python黑客入门暴力破解zip)
python高危漏洞(Python黑客入门暴力破解zip)
2024-11-08 10:18:30  作者:伱噓偽潒征  网址:https://m.xinb2b.cn/tech/eab228722.html


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

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


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

2.1 准备基本材料

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


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


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


2.2 ZIPFILE

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



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


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

import zipfile

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

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

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


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

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

import zipfile

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

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

运行这个脚本。


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

import zipfile

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

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

结果如下:


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

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

2.3 读取字典文件

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


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

import zipfile

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

for line in passFile.readlines():

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

print(password);

运行结果如下:


下面我们利用读取到的密码来暴力测试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进行异常捕获,密码不正确的时候,程序跳过继续执行。密码正确的时候打印密码,终止程序。运行结果如下:


到目前为止,我们的脚本已经具备了暴力破解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方法获取输入的参数,如果参数为空,则打印使用方法,退出程序。

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

无参数情况下:


输入参数:


2.6 小结

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

  • 不装电视的客厅如何选择(无电视客厅真的可行吗)
  • 2024-11-08无电视客厅真的可行吗目前国内家装设计流行无电视客厅设计,虽然电视以及不再是人们主要的娱乐方式,但无电视客厅真的可行吗?在回答这个问题之前,我先给大家普及客厅(LivingRoom)和家庭厅(FamilyRoom)的概念国。
  • 李大钊的扮演者是叫什么名(11位李大钊扮演者)
  • 2024-11-0811位李大钊扮演者最近,举国欢庆建党100周年,诸如陈独秀、李达、李大钊等革命先辈们,也生动形象地出现在我们面前,让我们了解了先辈们的光荣事迹恰恰是有一代又一代的优秀演员们来还原他们的形象,我们才能通过影视剧了解他们,。
  • 速8里的查理斯塞隆(查理兹塞隆演速激8遗憾没开跑车)
  • 2024-11-08查理兹塞隆演速激8遗憾没开跑车查理兹·塞隆说希望通过表演展现人性的好与坏,而杰森·斯坦森则说李连杰给了他启发与灵感新京报记者郭延冰摄塞隆与迪塞尔有不少对手戏塞隆说自己饰演的大反派给人不少神秘感、黑暗感3月23日晚,《速度与激情8》。
  • 2023款奥迪a7报价及图片(55TFSI尊享型价格78万)
  • 2024-11-0855TFSI尊享型价格78万街面上,奥迪A4L,奥迪A6L,奥迪Q5L,数量非常多,好多都看得审美疲劳了,然而有一款奥迪轿车,虽然销量不高,出镜率很低,但一开在街上,就很容易成为大众瞩目的焦点,回头率很高,无框车门撩人的溜背,令。
  • 卡地亚手镯经典款铂金版试戴(卡地亚情侣手镯推荐)
  • 2024-11-08卡地亚情侣手镯推荐情侣手表,情侣戒指,情侣鞋都有了?那不如换个思路,我们今天来聊聊情侣手镯,就情侣手镯而言,不少小朋友们都会考虑一些国际大品牌,卡地亚作为“皇帝的珠宝商”,估计很多人会选择卡地亚,不仅看重品牌的历史感,。
  • 古代如何如厕(古代如厕不简单)
  • 2024-11-08古代如厕不简单凡世间众生,均有饮食,有饮食就有屎尿,一有屎尿就必须“排泄”,道家谓之“五谷轮回”,唤厕所叫做“五谷轮回之所”但不要小看了这恶臭之所,在历史上这同样是一种文化,姑且唤作“厕所文化”现在如厕既舒服又方便。
  • brasilia在哪个国家(brasilia的简介)
  • 2024-11-08brasilia的简介Brasilia的中文译名是巴西利亚,它是巴西联邦共和国的首都,同时它也是巴西联邦共和国的第四大城市巴西利亚花费了三年多的时间才建成,它位于戈亚斯州境内巴西利亚是一座非常年轻、漂亮的首都,它内部有百分。
  • 4d厅的3d电影院(羊口有3D电影院啦)
  • 2024-11-08羊口有3D电影院啦纯进口荧幕、最高端的放映设备、舒适的观影环境、最新上线的影片……咱羊口人家门口的3D观影福利来了位于羊口镇艺体中心的3D影院建设正在收尾,只待荧幕安装完成后便可正式开门营业,届时,羊口居民在家门口就能。
  • 玩伽罗厉害的主播(主播小龙偶遇对面膨胀伽罗求针对)
  • 2024-11-08主播小龙偶遇对面膨胀伽罗求针对最近,王者荣耀迎来了S22赛季,说实话,这次改动蛮大的,对抗路新增了传送阵,暴君和主宰也引入了进化机制,看来又快有骚套路出现了要说最强王者套路王,那非ks主播小龙莫属,他是乌鸦坐飞机,峡谷推土机的创始。
  • 楚乔传李沁出现在哪几集(楚乔传江山美人榜第三期)
  • 2024-11-08楚乔传江山美人榜第三期榜单说明:每期根据当日播放内容,按照女演员在剧中颜值惊艳程度排序,已经领盒饭的自动退出本榜单,当日未出现的也不算入榜单,《楚乔传》播出日每日一期榜单实时更新,点击关注上方“暴有料”,及时收到最新榜单锦。
  • 沙区核心万科精装洋房即将首开(万科保利滨河湾)
  • 2024-11-08万科保利滨河湾行走居住与生活之间担当时代前行的引航者秉持[为生活更美好]的初心万科为城市再次创造新一代国际滨水住区——滨河湾翻开人居新篇章河流是造物的恩赐人类的文明于此滥觞,城市在河流两岸繁荣生长,一线临河的位置成。