忘记密码?不存在的, 教你如何使用python 暴力破解

忘记密码?不存在的, 教你如何使用python 暴力破解

 教你如何使用暴力破解

 

本文续上一期压缩文件,这期,我们来讨论一下如何在不知道密码的情况下进行暴力破解。

上期回顾:如何实现压缩文件通过python解密

 

01— 准备材料

 

这期准备材料比较少,都是基础代码。

1、掌握基础for循环,if判断。

2、掌握递归的用法。

 

02— 实现原理

 

我们来讨论一下暴力破解的实现原理吧!

首先我们来看一下,1,2这两个数字有多少种两位数以下的组合情况。

是的,有6种:1、2、11,12、21、22。

如果是123,有多少种两位数的组合情况。

12种,分别是:1、2、3、11,12、13、21、22、23、31、32、33

 

换种方式:

 

我们的密码是1位数的,请问有多少种情况!

答案是10种,0也是。密码从0到9的数字

那我如果我们设置的密码是两位数的,有多少种情况!

答案是100种。从00到99的数字。

 

那我们发现一个规律,对于这种简单的操作,那我们就可以使用一个for循环来解决。

 

代码如下:

"""纯数字密码破解"""
#这种情况不包含000001的情况。
zip_file = zipfile.ZipFile("zip.zip")
zip_list = zip_file.namelist()  # 得到压缩包里所有文件
for i in range(9999):
    x=str(i)
    y=False
    for f in zip_list:
        try:
            zip_file.extract(f, "zip",x.encode('utf-8'))  # 循环解压文件到指定目录
            print("密码正确,密码是"+x)
            y=True
        except BaseException as e:
            print("密码输入错误"+x)
            break
    if y==True:
        break
zip_file.close()  # 关闭文件,必须有,释放内存

 

 

上面这种是纯数字的破解方式,下面我们来实现不是纯密码的情况

 

 

list=[1,2,3]
for i in list:
    print(i)
    for j in list:
        print(i+j)
        for y in list:
            print(i+j+y)

 

如上,是基本原理,根据需要,我们可以自己添加需要的位数。上面这个是3位数以下的所有情况。

 

看了上面的代码,我们想做一下简化操作,如果密码有60位,那我们岂不是要写60个for循环。

 

那我们来看一下升级版:

"""字符串暴力破解"""
# 包含000001的情况。
# zmb="abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"
zmb = "abcdefg"
list = zmb.replace("", " ").split()
​
def blpj(list, num=2, x="", a=1, y=[]):
    a += 1
    for j in list:
        y.append(x + j)  # print(x+j)
        if a != num + 1:
            blpj(x=x + j, num=num, a=a, list=list)#内部调用自己,递归处理
    return len(y), y#返回一个密码组合列表。
​
print(blpj(list, num=4))#调用并打印,list根据自己的想要填下,比如是数字,或者只有字母

 

到此暴力破解算法结束,喜欢觉得点赞加关注呀!

 

相关推荐:

 

七夕表白代码

隐藏表白技能,python教你如何使用图片exif信息隐藏表白

七夕表白弹窗

二维码表白之二维码里面的小秘密

扫描下方二维码,关注我们,了解更多有趣的编程。

忘记密码?不存在的, 教你如何使用python 暴力破解

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111398.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 基于51单片机智能小车的设计与实现转弯避障_基于单片机的智能小车设计

    基于51单片机智能小车的设计与实现转弯避障_基于单片机的智能小车设计0引言学习智能小车系统,有助于提高搭建系统的能力和对自动控制技术的理解。智能小车是一个较为完整的智能化系统,而智能化的研究已成为我国追赶世界科技水平的重要任务。智能小车有它特有的特点:成本低,涉及的知识面广,易于拓展[1]。整个智能小车系统作为一个完整的系统,从它的原理图的实现到实物的完成的过程,不仅需要深厚的电子方面的知识,还有对电路实现的良好掌握,对于培养学生的实践能力都有重要的意义。智能小车…

    2022年10月17日
    0
  • 【PMP】项目浮动的三种时间「建议收藏」

    【PMP】项目浮动的三种时间「建议收藏」自由浮动时间不影响后续工作最早可以开始时间的前提下,这项工作可以拖延的时间叫做自由浮动时间。总浮动时间不影响项目总工期的情况下活动可以拖延的总时间。项目浮动时间在已经排好的总工期的基础上,领导或者甲方

    2022年8月1日
    2
  • 密码学与网络安全第七版部分课后习题答案[通俗易懂]

    密码学与网络安全第七版部分课后习题答案[通俗易懂]第0章序言1.课后题汇总(仅部分)第一章思考题:1、2、4、5第二章习题:10、12、16第三章习题:9第四章思考题:4、5、6第五章习题:11第六章习题:2、6第七章思考题:2、3、4习题:4、7、8第八章习题:2第九章思考题:5、6习题:2、3第十章习题:1、2第十一章思考题:1、2、3第十二章思考题:1、3、4、7第十三章思考题:…

    2022年5月21日
    36
  • 窗宽窗位

    窗宽窗位转自“CT诊断学”中的窗宽窗位部分。窗宽与窗位CT能识别人体内2000个不同灰阶的密度差别。而人的眼睛却只能分辨16个灰阶度。因此,人眼在CT图像上能分辨的CT值应为125Hu(2000/16)。换句话说,人体内不同组织CT值只有相差125Hu以上,才能为人眼所识别。人体软组织CT值多变化在20-50Hu之间,人眼就无法识别。为此,必须进行分段观察,才能使

    2022年6月15日
    64
  • pycharm把py文件改为exe文件_怎么把python程序打包成可执行文件

    pycharm把py文件改为exe文件_怎么把python程序打包成可执行文件1.安装pyinstraller工具2.在PyCharm最下方找到终端,在终端输入pyinstaller-F–onefilexxx.py

    2022年8月26日
    1
  • ajax跨域问题的解决方案「建议收藏」

    ajax跨域问题的解决方案「建议收藏」什么是跨域问题?跨域问题来源于JavaScript的”同源策略”,即只有协议+主机名+端口号(如存在)相同,则允许相互访问。也就是说JavaScript只能访问和操作自己域下的资源,不能访问和操作其他域下的资源。跨域问题是针对JS和ajax的,html本身没有跨域问题。查看浏览器开发者工具Console报错:Failedtoloadhttp://a.a.com:8080/A/FromServlet?userName=123:No‘Access-Control-Allow-Origin’

    2022年8月24日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号