爆密码的思路其实都大同小异:无非就是字典爆破,就看你是有现成密码字典,还是自己生成密码字典,然后进行循环输入密码,直到输入正确位置。现在很多都有防爆破限制,根本无法进行暴力破解,但是似乎zip这种大家都是用比较简单的密码而且没有什么限制。
因此 实现思路就是 生成字典->输入密码->成功解压
import itertools
def allkeyword(dic,num):
allkey1 = itertools.product(dic,repeat=num)
allkey2 = (''.join(i) for i in allkey1)
return allkey2
dictionaries = ['1', '2']
print(list(allkeyword(dictionaries,4)))
import zipfile
import itertools
dictionaries = ['1', '2', '3', '4','5','6','7','8','9','0',
'a','b','c','d','e','f','g','h','i','j','k',
'l','m','n','o','p','q','r','s','t','u','v',
'w','x','y','z'] #组成破解字典的关键字符(可以按照自己需求添加)
def allkeyword(): #排列出字符所有4个字符的组合
allkey1 = itertools.product(dictionaries,repeat=4)
allkey2 = (''.join(i) for i in allkey1)
return allkey2
def trypassword (password):
try:
ZIPFILE = zipfile.ZipFile(r'D:\123\1.zip') #定义对象,相当于定义一个压缩文件1.zip
ZIPFILE.extractall(path=r'D:\12',pwd=password.encode('utf-8'))
print(f"解压成功,正确密码为:{password}")
return True
except:
print(f"解压失败,尝试密码为:{password}")
return False
#用trypassword函数返回的True或者Flase来判定程序是否终止。
for pwd in allkeyword() :
if trypassword(pwd):
break
到此这篇关于Python实现暴力破解有密码的zip文件的文章就介绍到这了,更多相关Python暴力破解有密码的zip文件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!