1.前言
2.安装
安装python包pywifi,由于依赖comtypes,使用的时候还得装上comtypes。
pip install pywifi pip install comtypes
3.教程文档
# 引入pywifi库及所带常量库 import pywifi from pywifi import const, Profile # 1. 基础 # 获取网卡接口 wifi = pywifi.PyWiFi() # 得到第一个无线网卡 ifaces = wifi.interfaces()[0] # 切断网卡连接 ifaces.disconnect() # 获取wifi的连接状态 wifistatus = ifaces.status() # 检查wifi是否处于切断状态 if wifistatus == const.IFACE_DISCONNECTED: # 网卡已被切断 pass # 如果网卡没有被切断 # 或者使用 " if wifistatus == const.IFACE_CONNECTED: " else: # 已连接wifi pass # 如果已经切断网卡,一般执行下述操作 if wifistatus == const.IFACE_DISCONNECTED: # 设置wifi连接文件 profile: Profile = pywifi.Profile() # 你要连接的网络的名称 profile.ssid = " " # 网卡的开放状态 # " Auth - AP "的验证算法 profile.auth = const.AUTH_ALG_OPEN # wifi的加密算法 # 通常的加密算法值为 " WPA " # 选择wifi的加密方式 # " Akm - AP "的密钥管理 profile.akm.append(const.AKM_TYPE_WPA2PSK) # 加密单元 # " Cipher - AP "的密码类型 profile.cipher = const.CIPHER_TYPE_CCMP # 设置密码 password = " " # 回调密码(wifi密码) # 如果没有密码,则设置值为 " CIPHER_TYPE_NONE " profile.key = password # 删除已连接的所有wifi文件 ifaces.remove_all_network_profiles() # 加载新的wifi连接文件 tep_profile = ifaces.add_network_profile(profile) # 连接上面的wifi文件 ifaces.connect(tep_profile) # 如果wifi已连接 if ifaces.status() == const.IFACE_CONNECTED: print(True) # 如果仍未连接 else: print(False) # 2.提高 # 获取wifi接口名称 name = ifaces.name() # 扫描wifi ( AP ) ifaces.scan() # 查看上面的wifi扫描结果 ( 返回值为列表 ) result = ifaces.scan_results() # 删除所有的AP配置文件 # 目的是为了接下来的连接 ifaces.remove_all_network_profiles() # 返回配置文件的列表 files = ifaces.network_profiles() # 设置配置文件的名字 ifaces.add_network_profile(profile) # 连接wifi ifaces.connect(profile) # 断开wifi ifaces.disconnect() # wifi的连接状态 ifaces.status() # 配置文件 profile = pywifi.Profile() # 配置文件的方法 # ssid auth akm cipher key # 这些的详细讲解可看基础 # pywifi中const的量 # const.IFACE_DISCONNECTED = 0 # const.IFACE_SCANNING = 1 # const.IFACE_INACTIVE = 2 # const.IFACE_CONNECTING = 3 # const.IFACE_CONNECTED = 4 # Auth - AP var1 = const.AUTH_ALG_OPEN var2 = const.AUTH_ALG_SHARED # Akm - AP # 不安全的方法 var3 = const.AKM_TYPE_NONE # WPA的方法 var4 = const.AKM_TYPE_WPAPSK # WPA2的方法 var5 = const.AKM_TYPE_WPA2PSK # 对于企业的方法 var6 = const.AKM_TYPE_WPA var7 = const.AKM_TYPE_WPA2 # Cipher - AP var8 = const.CIPHER_TYPE_NONE var9 = const.CIPHER_TYPE_WEP var10 = const.CIPHER_TYPE_TKIP var11 = const.CIPHER_TYPE_CCMPView Code
profile = pywifi.Profile() profile.ssid = ssid profile.auth = auth profile.akm.append(akm) profile.cipher = cipher if cipher != const.CIPHER_TYPE_NONE: profile.key = key 1. ssid:AP的用户名 2. auth:AP的认证算法 - const.AUTH_OPEN - const.AUTH_SHARED 3. akm:AP的密钥管理类型 - const.AKM_TYPE_NONE - const.AKM_TYPE_WPA - const.AKM_TYPE_WPAPSK - const.AKM_TYPE_WPA2 - const.AKM_TYPE_WPA2PSK 4. cipher:AP的密码类型 - const.CIPHER_TYPE_NONE - const.CIPHER_TYPE_WEP - const.CIPHER_TYPE_TKIP - const.CIPHER_TYPE_CCMP 5. key:AP的密码 - 如果cipher不是CIPHER_TYPE_NONE,则应设置此值。
4.基本用法
连接WIFI
def connect_wifi(): wifi = pywifi.PyWiFi() # 创建一个wifi对象 ifaces = wifi.interfaces()[0] # 取第一个无限网卡 print(ifaces.name()) # 输出无线网卡名称 ifaces.disconnect() # 断开网卡连接 time.sleep(3) # 缓冲3秒 profile = pywifi.Profile() # 配置文件 profile.ssid = "" # wifi名称 profile.auth = const.AUTH_ALG_OPEN # 需要密码 profile.akm.append(const.AKM_TYPE_WPA2PSK) # 加密类型 profile.cipher = const.CIPHER_TYPE_CCMP # 加密单元 profile.key = '' # wifi密码 ifaces.remove_all_network_profiles() # 删除其他配置文件 tmp_profile = ifaces.add_network_profile(profile) # 加载配置文件 ifaces.connect(tmp_profile) # 连接 time.sleep(5) # 5秒后检查连接状态 isok = True if ifaces.status() == const.IFACE_CONNECTED: print("成功连接") else: print("失败") # ifaces.disconnect() # 断开连接 time.sleep(1) return isok
扫描WIFI
def scan_wifi(): # 扫描附近wifi wifi = pywifi.PyWiFi() iface = wifi.interfaces()[0] iface.scan() time.sleep(1) basewifi = iface.scan_results() # for i in basewifi: # print('wifi扫描结果:{}'.format(i.ssid)) # ssid 为wifi名称 # print('wifi设备MAC地址:{}'.format(i.bssid)) return basewifi