用python破解了同事的加密压缩包! 惊呆了 - Go语言中文社区

用python破解了同事的加密压缩包! 惊呆了


文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理。

事情的经过是这样的:

又是奶茶,行吧行吧。

快点开工,争取李大伟回来之前搞定。

李大伟说是6位数字密码

那么我们可以利用python生成全部的六位数字密码

#生成从000000到99999的密码表

f = open(‘passdict.txt’,‘w’)

for id in range(1000000):

password = str(id).zfill(6)+’n’

f.write(password)

f.close()

这样,我们就生成了一个从000000到99999的密码表。

并把它们存入到 passdict.txt 的文件中。

6位的密码表就这么大!!!

下一步做什么?

自然是将生成的密码表中的密码遍历,

暴力破解啦!

科普时间:

zipFile模块式Python自带的模块,提供了对zip 文件的创建,读,写,追加,解压以及列出文件列表的操作

解压使用extractll方法extractall(path=None, members=None, pwd=None)

  • path:指定解压后文件的位置
  • members:(可选)指定要Zip文件中要解压的文件,这个文件名称必须是通过namelist()方法返回列表的子集
  • pwd:指定Zip文件的解压密码

那么我们可以利用 zipFile 模块来遍历密码表,

挨个挨个密码尝试,看能不能打开压缩包。

直到成功。

导入zipFile

import zipfile

def extractFile(zipFile, password):

try:

zipFile.extractall(pwd= bytes(password, “utf8” ))

print(“李大伟的压缩包密码是” + password) #破解成功

except:

pass #失败,就跳过

def main():

zipFile = zipfile.ZipFile(‘李大伟.zip’)

PwdLists = open(‘passdict.txt’) #读入所有密码

for line in PwdLists.readlines(): #挨个挨个的写入密码

Pwd = line.strip(’n’)

guess = extractFile(zipFile, Pwd)

if name == ‘main’:

main()

花了不到一分钟

成功解出密码是:

李大伟设置的只是6位数字的密码,

所以本次只要单线程暴力遍历就ok了。

那如果更多位数,

字母数字特殊字符混合的复杂密码呢?

我们可以应用多线程进程解压,加快速度

网络上还有一些暴力破解字典,

可以下载用来遍历

对Python感兴趣或者是正在学习的小伙伴,可以加入我们的Python学习扣qun:855408893 ,从0基础的python脚本到web开发、爬虫、django、数据挖掘数据分析等,0基础到项目实战的资料都有整理。送给每一位python的小伙伴!每晚分享一些学习的方法和需要注意的小细节,学习路线规划,利用编程赚外快。点击加入我们的 python学习圈

感兴趣的朋友们不妨试试。

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/NNNJ9355/article/details/103723047
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-02-25 01:32:30
  • 阅读 ( 1072 )
  • 分类:

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢