脚本功能:
#!/usr/bin/env python # -*- coding: UTF-8 -*- # Author:Leslie-x import itertools as its import threading import rarfile import os words = '0123456789abcdefghijklmnopqrstuvwxyz' # 涉及到生成密码的参数 flag = True # 是否关闭线程的标志 def append_on_file(password,file_name): # 把解析出的密码写入到文件中 with open('password.txt', 'a', encoding='utf8') as f: text = file_name+':'+password + '\n' f.write(text) def get_password(min_digits, max_digits, words): """ :param min_digits: 密码最小长度 :param max_digits: 密码最大长度 :param words: 密码可能涉及的字符 :return: 密码生成器 """ while min_digits <= max_digits: pwds = its.product(words, repeat=min_digits) for pwd in pwds: yield ''.join(pwd) min_digits += 1 def extract(File,file_name): """ 若线程关闭标志为True,就执行循环,从密码生成器中取出密码,验证密码是否正确 密码正确,则把密码写入文件中,并将线程关闭标志flag设定为False,通知其他线程关闭 """ global flag while flag: p = next(passwords) try: File.extractall(pwd=p) # 打开压缩文件,提供密码... flag = False print("password is " + p) ###破解到密码 append_on_file(p,file_name) break except: print(p) def mainStep(file_path,file_name): """ 多线程并发验证密码 :param file_path: rar压缩文件路径列表 :return: """ file = rarfile.RarFile(file_path) for pwd in range(3): t = threading.Thread(target=extract, args=(file,file_name)) t.start() if __name__ == '__main__': # 主程序 base_dir = r'E:\迅雷下载\rar' for file_info in os.listdir(base_dir): try: # 拼接压缩文件路径 file_path = os.path.join(base_dir, file_info) # 压缩文件名称 file_name = file_info.split('.')[0] # 生成密码字典:密码长度最小为4,最大为11 passwords = get_password(4, 11, words) # 将任务分发给线程执行 mainStep(file_path,file_name) except: pass
注意:当前脚本在知道密码长度大概范围,可能涉及的字符具体范围下效率可行;如果对密码长度和涉及字符完全不知,撞库难度非常大
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
8.1 密码在线破解 为了使用户能成功登录到目标系统,所以需要获取一个正确的密码。在Kali中,在线破解密码的工具很多,其中最常用的两款分别是Hydra和Medusa。本节将介绍使用Hydra和Medusa工具实现密码在线破解。 8.1.1 Hydra工具 Hydra是一个相当强大的暴力密码破解工具。该工具支持几乎所有协议的在线密码破解,如FTP、HTTP、HTTPS、MySQL、MS SQL、O
本文向大家介绍Python爬取破解无线网络wifi密码过程解析,包括了Python爬取破解无线网络wifi密码过程解析的使用技巧和注意事项,需要的朋友参考一下 前言 今天从WiFi连接的原理,再结合代码为大家详细的介绍如何利用python来破解WiFi。 Python真的是无所不能,原因就是因为Python有数目庞大的库,无数的现成的轮子,让你做很多很多应用都非常方便。wifi跟我们的生活息息相关
问题内容: 使用深度嵌套的python字典,我希望能够在这样的数据结构中分配值: 无需检查mydict [key]等实际上是否设置为dict,例如使用 附属词典的创建应即时进行。允许等效的最优雅的方法是什么-也许在标准上使用装饰器? 问题答案: class D(dict): def missing(self, key): self[key] = D() return self[key]
本文向大家介绍Python生成随机密码,包括了Python生成随机密码的使用技巧和注意事项,需要的朋友参考一下 本人 python新手,使用的环境是python2.7,勿喷 以上就是本文的全部内容了,希望对大家学习python能够有所帮助。
<?php $pw='simplewind'; $afpw=sp_password($pw);//加密字符串 echo $afpw;//输出加密后的字符串 ?>
在Java代码中,我应该解密一个加密的单词,如下所示: 我是加密新手,但是我发现了一些如何用Java加密/解密一些AES/CBC的示例。但是它需要盐、密钥和Iv。我发现OpenSsl正在从“密码”中导出这些值,但我没有发现如何Java解密加密值。 有人知道它是怎么工作的吗?盐、钥匙和/或Iv是否存储在加密值中?谢谢你的回答。