- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试验证用户为 WPA 连接输入的 SSID 和 WPA 密码。我的程序是运行在嵌入式Linux平台上的Python程序。我可以通过解析 iwlist scan
子进程的输出来验证具有 SSID 的接入点是否存在。然而,验证密码短语并不那么直接。到目前为止,我想出的唯一解决方案是解析
wpa_supplicant -Dwext -iwlan0 -c/tmp/wpa_supplicant.conf
寻找
"pre-shared key may be incorrect"
或内核消息
"OnDeAuth Reason code(15)"
(根据 wpa_supplicant 源,这意味着 WLAN_REASON_4WAY_HANDSHAKE_TIMEOUT)。
将握手超时解释为无效的密码似乎是完全错误的。除此之外,该方法需要等待子进程的一些输出,并假设没有错误消息意味着密码有效。
谷歌搜索只会让我返回很多关于如何破解 WPA 连接的问题和建议!我的目标平台的 yum 存储库中没有 wpa_cli
或 iwevent
,我不确定如何让第三方 python 包在我的目标上运行。
问题:验证 Wifi WPA 密码的最简单方法是什么?
最佳答案
好吧,满足您的需求的一种不太直接(但唯一可能)的方法是启动与 AP 的四次握手。
由于您使用 Python 进行编码,因此 Scapy 将是制作 EAPOL 消息数据包的最佳选择。
不过,您必须了解 EAPOL 数据包的结构,并在您的代码中完全实现它。
您还必须在 Python 中重新编码 key 生成函数,其中大部分(如果不是全部)是 PRF **(伪随机函数);或者,您可以导入现成编译的 .DLL 来为您进行编码。
但是,只管理四次握手的前 3 条消息就足够了:
如果在多次连接尝试后,AP 没有发送第三条 key 消息,那么来自 STA 的 MIC(消息完整性检查)与 AP 生成的 MIC(消息完整性检查)不匹配,因此密码无效。
否则就是。
注意:wpa_supplicant 遵循相同的身份验证和连接程序,但是它会继续获取额外信息,例如 IP 地址等等...这就是为什么我说这是唯一可能的方式。
关于linux - 如何在 Linux 上以编程方式验证 WPA 密码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17484086/
我为 CLR 提供程序记录 ETW 事件: xperf -start clr -on e13c0d23-ccbc-4e12-931b-d9cc2eee27e4 -f clr.etl ... xperf
我正在编写一个应用程序,允许用户使用 PEAP 或 TTLS 和证书轻松地将 android 连接到企业无线网络。 我可以添加一个基于 EAP 的 wifi 配置文件,并让它使用正确的凭据和证书将 w
我经常乘公共(public)汽车旅行,其中大部分都提供某种形式的车载 WiFi。使用像 Wicd 这样的自动连接管理器连接到它们的通常方法是选择网络,然后在启动浏览器时进行一些额外的身份验证,我就完成
当我使用NEHotspotConfigurationManager加入具有64个十六进制数字的wpa2网络时,我收到错误: NEHotspotConfiguration invalid WPA/WPA
我尝试编写一个 Python 程序来计算 WPA 握手,但我在哈希方面遇到了问题。为了比较,我安装了 cowpatty (看看我从哪里开始出错)。 我的 PMK 生成工作正常,但 PTK 计算似乎总是
我需要将 headless 物联网设备 (Raspberry Pi) 连接到 Wi-Fi 网络。我有使用 YoctoProject 构建的自定义 Linux。我没有安装 connman 或 Netwo
Cydia中的eWifi、WiFiFoFum等wifi扫描应用程序可以知道安全类型。使用 Apple80211 api 时,应用程序如何知道 OPEN、WPA、WPA2、WEP 等安全类型? CAPA
因此,在我的应用程序中,我将连接到给定 SSID 和网络 key 的 WiFi 网络。它运行良好,如果使用广播接收器连接成功,用户会收到通知。现在我只需要能够告诉用户是否存在身份验证问题(即给定的 k
我正在尝试获取 2 个函数来验证 SSID 和 WPA2 密码。 function isValidSSID(ssid) { return (regex) } 和 function isVali
我正在用 C 为 linux 编写一个程序,以从 Windows 注册表配置单元中提取 wpa/wep key 。 最初我希望使用 wine 的 CryptUnprotectData 函数,但现在我意
我正在尝试验证用户为 WPA 连接输入的 SSID 和 WPA 密码。我的程序是运行在嵌入式Linux平台上的Python程序。我可以通过解析 iwlist scan 子进程的输出来验证具有 SSID
这是我的问题: 如果我连接到网络(所以我知道 WPA/WPA2-PSK),我希望能够解密我从网络中的其他设备捕获的流量。 (如果使用 WEP,tcpdump 会自动执行此操作)。 据我所知,WPA 为
我在 React+Nodejs 上有一个中等规模的项目,我需要为移动部分选择最合适的技术。为此,我正在考虑使用 React Native 或 Web Progressive Apps。我想问你们,到目
我浏览过 stackoverflow 本身以及其他博客和网站上关于以编程方式连接到 WiFi 网络的几个话题。我得到了他们的指南并开发了一个代码 fragment ,发布在下面。我的住处有一个 pro
我试图计算 WPA 握手数据包的 MIC,但不幸的是它失败了。更准确地说,我采用了 802.1x 数据包(如规范所述)。 MIC = HMAC_MD5(MIC Key, 16, 802.1x data
尝试以编程方式从 Android 连接到我的无线网络。 安全类型是WPA2,加密AES。 这没有按预期工作: private WifiConfiguration saveWepConfig(Strin
几个月前,我开始开发一些 WiFi-Direct 应用程序。几天前,我将我的两个 Galaxy Nexus 都更新为 Jelly Bean (4.1.x) 并测试了我的应用程序,但似乎又出现了问题。获
我的 Nexus One (Gingerbread) 和 Samsung Galaxy Tab (Honeycomb) 都停止连接到我使用 WPA/WPA2 无线连接的公司网络。奇怪的是,这两种设备至
尝试列出网络属性时 - https://w1.fi/wpa_supplicant/devel/dbus.html#dbus_network使用 dbus-cpp 我收到一些关于丢失 operator=
我正在尝试使用 java 创建一个随机 WPA 密码生成器,以便为我提供尽可能安全的 Wifi 密码,并且可以在我需要时进行更改。 是否有一种方法可以使用 WPA(2) 密码中允许使用的所有字符快速填
我是一名优秀的程序员,十分优秀!