事情大概是这样的,小明同学昨天加密了一个压缩包,他一般把密码设置为当天的日期,如191210。可是他怎么也打不开了,也就是忘记密码了。我们帮他解决一个这个问题。
首先利用python生成全部的六位数密码,生成从000000到999999的密码表
f = open('passdict.txt','w')
for id in range (1000000):
password = str(id).zfill(6)+'\n'
f.write(password)
f.close()
这样就生成了一个从000000到999999的密码表,并把它存入到passdict.txt的文件中。
下一步就是将生成的密码表中的密码遍历(暴力破解)
知识点补充
zipFile模块式Python自带的模块,提供了对zip文件的创建,读,写,追加,解压以及列出文件列表的操作
解压使用extractll方法extractll(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位数字的密码,所以用单线程暴力遍历就可以。