0

    Python生成遍历暴力破解密码,实战的效果差强人意了

    2023.05.28 | admin | 207次围观

    这个也就是提供一个思路,需求是这样的,我XX的闺蜜有个rar的压缩包,不知道他是从哪里挣来的,说这个对他比较重要有密码的压缩包,但是有密码打不开,唉,可怜了我的电脑了

    因为这个是暴力破解,是把所有的密码进行的遍历,也就是从1到。。。。无穷的列举出来,然后按个密码去撞,撞开了就开了,建议大家买个云服务器进行破解哈,因像这种的第一,不知道密码是几位的,第二还有特殊符号的,唉,破解时间太长了,就用8位密码来说吧,全部8位测试完密码也得5个小时,笔记本那是嗡嗡的,为了自己的电脑,还不如掏个钱买个云服务器让他自己跑着测密码去,一小时也才2元钱,最低配置的哈。。。。

    先看效果图

    私信小编01即可获取大量Python学习资源

    别看这个1234密码简单,但是对于程序来说这个也是从1111然后1112然后1113一次类推,暴力到的1234

    直接上Python源码

    
    import itertools as its     ##这个库,python自带的
    import rarfile   #这个是操作rar压缩包的,如果你需要破解别的密码的话,比如pdf,那么请你安装下pdf的第三方库
    ### 这个根据需要来,这边测试的是破解rar压缩包
    path1 = "E:\\python2\\rar\\1.rar"  # 需要解压的文件路径及地址
    path2 = "E:\\python2\\rar"  # 需要解压到的文件夹地址
    ##下面的是你的密码可能用的字符#
    words = "1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!#$%&'( )*+,-./:;<=>?@[]^_`{|}~"    ##密码里面含有大小写字母,数字以及特殊符号
    re=4        ##这个是与下面的repeat相对应的,代表你需要生成几位的数组。这里是4,代表生成4位的数组。
    while 2>1:
        r = its.product(words,repeat=re)
        for i in r:
            # print(type(i))
            a ="".join(i)        ##通过.join将数组里面的元素转换成字符串
            print("当前测试密码:",a)
    		###尝试测试密码,如果错误continue,进入下一次循环
            try:
                rf = rarfile.RarFile(path1)  # pwd为解压密码
                rf.extractall(path=path2, pwd=a)
                print('密码破解成功:',a)
                exit(0)
            except Exception as e:
                print(e)
                continue
        else:
            re+=1       ###如果将所有的4位字符组合尝试完成后,还是没有破解到密码,那么会将4再加上1,进行5位数的破解(这里没有具体写出,为了代码的整洁,没有写出如何循环到5位数密码)
    

    结束语

    密码都可以破解成功的,只是时间的问题,如果是9位数的话估计的好几天了,所以说,如果知道点密码的详情也好,那怕知道是几位数的密码,等也让咱等的值得

    比如我这个有密码的压缩包,我习惯性的把密码从6位开始破解了,一直破解到8位还是没破解开,人家的密码设置成了5位数,你说气人不

    版权声明

    本文仅代表作者观点。
    本文系作者授权发表,未经许可,不得转载。

    发表评论