Python如何实现查看WiFi密码?

由于最近公司加强对无线安全的管理,wifi密码从以前的12345678,变成复杂难记的一串,导致我时常忘记WIFI密码,而遭受同事的"毒打"。由于我不是那种喜欢打扰同事认真工作的人,于是,我决定用python来试试,看看能不能读取到已连接过WIFI的密码,这样就不用老是叨扰别人了!

1. windows查看WIFI密码的方法

经过我的一番思考和查阅资料(搜索引擎),原理大致是这样。 通过windows的wifi属性查看密码。这种方式,操作起来相当麻烦,一般人根本找不到。即使第一次找到了,找第二次也要折磨死人。

另外,我们可以使用命令行来实现上述操作:

shell 复制代码
netsh wlan show profiles

列出已连接wifi的列表 然后再使用命令 ``netsh wlan show profiles WiFi名称 key=clear:

shell 复制代码
netsh wlan show profiles ZXQ key=clear

查看安全设置获得密码:

上面的方式,仍然比较麻烦,对于我这种懒人来说,实在是有点聒噪!我就想快速的查看密码,不要输入!

想到python也可以执行cmd命令,那么第二种命令行的方式,不就可以用python来实现了吗?!

2. 使用subprocess模块

subprocessPython标准库中的一个模块,用于在Python程序中执行外部命令或子进程。它可以通过创建子进程并与其进行通信,来调用系统命令或其他可执行文件。

subprocess模块提供了多个函数来调用子进程,如subprocess.run()subprocess.Popen()等。这些函数可以执行命令并返回执行结果,也可以通过传递参数和读取标准输入输出进行进程间的通信。

python 复制代码
import subprocess

def get_wifi_password():
    # 调用系统命令,获取WiFi密码
    result = subprocess.check_output(['netsh', 'wlan', 'show', 'profile'])
    result = result.decode('gbk')  # 将命令输出转换为字符串

    # 提取WiFi名称
    profiles = [i.split(':')[1][1:-1] for i in result.split('\n') if '所有用户配置文件' in i]

    # 获取各个WiFi网络的密码
    passwords = []
    for profile in profiles:
        password = subprocess.check_output(['netsh', 'wlan', 'show', 'profile', 'name=' + profile, 'key=clear'])
        password = password.decode('gbk')  # 转换为字符串
        password = [i.split(':')[1][1:-1] for i in password.split('\n') if '关键内容' in i]
        passwords.append((profile, password[0]))

    return passwords

# 调用函数获取WiFi密码
wifi_passwords = get_wifi_password()

# 打印WiFi名称和密码
for wifi in wifi_passwords:
    print(f'WiFi名称:{wifi[0]},密码:{wifi[1]}')

Got it!, 有了这个脚本,这不就是点一下的事么。在这个示例代码中,我们使用subprocess.check_output 函数调用了 netsh 命令来获取已连接WiFi网络的信息。获取到的信息中包含WiFi网络的名称和密码。

送给公司行政的小姐姐用,下次她见到我,不得叫一声大哥?

3. pywifi模块暴力破解

PyWifi 是一个用于操作WiFi的第三方库,提供了方便的API以获取WiFi信息。其本身并不支持获取已连接过的wifi的密码。该库主要用于连接、断开以及扫描wifi网络。

首先,我们需要使用pip命令来安装pywifi库:

shell 复制代码
pip install pywifi

由于此模块基于 comtypes 模块,因此同时需要下载此模块:

shell 复制代码
pip install comtypes

使用 PyWifi,首先我们需要创建一个PyWifi 对象:

python 复制代码
#-*-coding:utf-8-*-
import pywifi,time
from pywifi import const

def scan_wifi():
    wifi = pywifi.PyWiFi()
    iface = wifi.interfaces()[0] #acquire the first Wlan card,maybe not
    iface.scan() # 扫描wifi
    time.sleep(1) # 休息一下
    basewifi = iface.scan_results()
 
    for i in basewifi:
        print("wifi scan result:{}".format(i.ssid))
        print("wifi device MAC address:{}".format(i.bssid))
        
        # 尝试连接wifi
        profile = pywifi.Profile()                          #配置文件
        profile.ssid = i.ssid                        #wifi名称
        profile.auth = const.AUTH_ALG_OPEN                  #需要密码
        profile.akm.append(const.AKM_TYPE_WPA2PSK)          #加密类型
        profile.cipher = const.CIPHER_TYPE_CCMP             #加密单元
        profile.key = gen_key()                            #wifi密码
        
        iface.remove_all_network_profiles()                #删除其它配置文件
        tmp_profile = iface.add_network_profile(profile)   #加载配置文件
        iface.connect(tmp_profile)
        time.sleep(5)
        if iface.status() == const.IFACE_CONNECTED:
            print("connect successfully!")
        else:
            print("connect failed!")
        time.sleep(1)
    return basewifi

def gen_key():
    # 生成wifi破解密码,通用做法是读取密码字典库
    pass

if __name__ == '__main__':
    scan_wifi()

因此,小伙伴们要当心哦,wifi密码设置要复杂!否则被人偷用网络都不知道哦! 当然咯,这个暴力破解的方法耗时也不稳定,而且也不一定正确,本文只是从技术角度来阐述如何使用Python来玩WIFI, 并不建议大家做任何破坏性的操作和任何不当的行为。

上一篇:Python中的交互式数据可视化工具Streamlit

4.总结

为了能够快速查看 Wi-Fi 密码,我们介绍了两种方法:一种是通过 Windows 的 Wi-Fi 属性查看密码,另一种是使用Python 中的 subprocess 模块来执行命令行获取密码;

另外呢,有个名为 PyWifi 的第三方库,它可以用于操作 Wi-Fi,并提供了简单的 API 来获取 Wi-Fi 信息。比较适合我们获取到该网络的信息,以及使用 pywifi 模块实现一些更高级的功能,例如检测 Wi-Fi 网络的质量、分析数据流量等等。

如果你觉得文章还不错,记得关注公众号: 锅外的大佬 我的博客