美文网首页大数据 爬虫Python AI SqlPython小哥哥
Python黑客入门:暴力破解zip,零基础也可以学会!

Python黑客入门:暴力破解zip,零基础也可以学会!

作者: 14e61d025165 | 来源:发表于2019-05-25 14:52 被阅读0次
    <tt-image data-tteditor-tag="tteditorTag" contenteditable="false" class="syl1558767123706" data-render-status="finished" data-syl-blot="image" style="box-sizing: border-box; cursor: text; color: rgb(34, 34, 34); font-family: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "WenQuanYi Micro Hei", "Helvetica Neue", Arial, sans-serif; font-size: 16px; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: normal; orphans: 2; text-align: left; text-indent: 0px; text-transform: none; white-space: pre-wrap; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px; background-color: rgb(255, 255, 255); text-decoration-style: initial; text-decoration-color: initial; display: block;"> image

    <input class="pgc-img-caption-ipt" placeholder="图片描述(最多50字)" value="" style="box-sizing: border-box; outline: 0px; color: rgb(102, 102, 102); position: absolute; left: 187.5px; transform: translateX(-50%); padding: 6px 7px; max-width: 100%; width: 375px; text-align: center; cursor: text; font-size: 12px; line-height: 1.5; background-color: rgb(255, 255, 255); background-image: none; border: 0px solid rgb(217, 217, 217); border-radius: 4px; transition: all 0.2s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;"></tt-image>

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

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

    Python学习交流群:1004391443,这里有资源共享,技术解答,还有小编从最基础的Python资料到项目实战的学习资料都有整理,希望能帮助你更了解python,学习python

    2.1准备基本材料

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

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

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

    2.2 ZIPFILE

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

    如果你在学习Python的过程当中有遇见任何问题,可以加入我的python交流学习qq群:250933691,多多交流问题,互帮互助,群里有不错的学习教程和开发工具。学习python有任何问题(学习方法,学习效率,如何就业),可以随时来咨询我

    这里我们首先关注下 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');

    forlineinpassFile.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对象 ,解压的目标路径,密码,如果解密成功则返回密码。

    defextractFile(toPath,zFile,password):

    try:

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

    returnpassword;

    exceptException,e:

    return;

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

    defmain():

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

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

    forlineinpassFile.readlines():

    password = line.strip('N');

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

    ifguess:

    print('SCUCESS'+password);

    exit(0);

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

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

    import zipfile

    defextractFile(toPath,zFile,password):

    try:

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

    print('SCUCESS'+password);

    returnpassword;

    exceptException,e:

    return;

    defmain():

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

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

    forlineinpassFile.readlines():

    password = line.strip('N');

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

    ifguess:

    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):

    printparse.usage;

    exixt(0);

    else:

    zname=options.zname;

    dname=options.dname;

    zFile = zipfile.ZipFile(zname);

    passFile = open(dname);

    forlineinpassFile.readlines():

    password = line.strip(' ');

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

    ifguess:

    print('scucess'+password);

    exit(0);

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

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

    无参数情况下:

    输入参数:

    2.6 小结

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

    相关文章

      网友评论

        本文标题:Python黑客入门:暴力破解zip,零基础也可以学会!

        本文链接:https://www.haomeiwen.com/subject/bktzzqtx.html