Wi-Fi Framework:一款功能强大的WiFi安全测试工具

关于Wi-Fi Framework

Wi-Fi Framework是一款功能强大的WiFi安全测试工具,该工具本质上来说是一个安全框架,可以帮助广大研究人员更轻松地执行Wi-Fi安全测试。除此之外,我们还可以利用Wi-Fi Framework来创建模糊测试工具,设计新的测试方案,创建PoC以验证漏洞,自动化渗透测试或开发其他的漏洞测试工具。

该框架的主要优点是,它允许我们重用Linux的Wi-Fi功能,以便更轻松地实施安全测试。比如说,该框架可以帮我们连接(受保护的)Wi-Fi网络,并在测试客户端时为我们广播信标。一般来说,Linux的任何Wi-Fi功能都可以重用,以更快地实施安全测试。

Wi-Fi Framework架构

下图显示的是Wi-Fi Framework中Wi-Fi守护进程和框架组件架构:

工具安装

该框架可以在本地Linux系统或虚拟机环境中运行。

首先,我们需要使用下列命令将该项目源码克隆至本地:

gitclonehttps://github.com/domienschepers/wifi-framework.git

接下来,使用下列命令安装工具所需的依赖组件:

apt-getupdate

apt-getinstallgitmakegccpython3-venvnet-tools

apt-getinstalllibdbus-1-devlibnl-3-devlibnl-genl-3-devlibnl-route-3-devlibssl-dev

安装完成之后,使用下列命令安装框架:

cd ../dependencies

./build.sh

cd ../setup

./pysetup.sh
libwifi

libwifi库作为一个git只模块使用,需要手动安装:

gitsubmoduleinit

gitsubmoduleupdate

工具使用

初始化并激活Python环境:

sourcesetup/venv/bin/activate

模拟Wi-Fi网络接口:

./setup-hwsim.sh4

运行工具并创建测试用例:

usage: run.py [-h] [--configCONFIG] [--binaryBINARY] [--debugDEBUG] ifacename

指定网络配置信息:

cdsetup

ln-ssupplicant-wpa3-personal.confsupplicant.conf

工具使用样例

假设我们现在需要测试客户端是否使用全零密钥去加密帧数据,而这种情况可能发生在密钥重新安装攻击期间。那么在Wi-Fi Framework的帮助下,我们无需重新实现接入点的所有功能,只需编写以下测试用例即可:

classExampleKrackZerokey(Test):

name="example-krack-zero-key"

kind=Test.Authenticator



def__init__(self):

super().__init__([

# Replay4-WayHandshakeMessage3/4.

Action( trigger=Trigger.Connected, action=Action.Function ),

# Receiveallframesandsearchforoneencryptedwithanall-zerokey.

Action( trigger=Trigger.NoTrigger, action=Action.Receive ),

# Whenwereceivesuchaframe, wecanterminatethetest.

Action( trigger=Trigger.Received, action=Action.Terminate )

])





defresend(self, station):

# Resend4-WayHandshakeMessage3/4.

station.wpaspy_command("RESEND_M3 "+station.clientmac )





defreceive(self, station, frame):

ifframe[Dot11].addr2!=station.clientmacornotframe.haslayer(Dot11CCMP):

returnFalse



# CheckifCCMP-encryptedframecanbedecryptedusinganall-zerokey

plaintext=decrypt_ccmp(frame.getlayer(Dot11), tk=b"\x00"*16)

ifplaintextisNone: returnFalse



# Wereceivedavalidplaintextframe!

log(STATUS,'Client encrypted a frame with an all-zero key!', color="green")

returnTrueclassExampleKrackZerokey(Test):

name="example-krack-zero-key"

kind=Test.Authenticator



def__init__(self):

super().__init__([

# Replay4-WayHandshakeMessage3/4.

Action( trigger=Trigger.Connected, action=Action.Function ),

# Receiveallframesandsearchforoneencryptedwithanall-zerokey.

Action( trigger=Trigger.NoTrigger, action=Action.Receive ),

# Whenwereceivesuchaframe, wecanterminatethetest.

Action( trigger=Trigger.Received, action=Action.Terminate )

])





defresend(self, station):

# Resend4-WayHandshakeMessage3/4.

station.wpaspy_command("RESEND_M3 "+station.clientmac )





defreceive(self, station, frame):

ifframe[Dot11].addr2!=station.clientmacornotframe.haslayer(Dot11CCMP):

returnFalse



# CheckifCCMP-encryptedframecanbedecryptedusinganall-zerokey

plaintext=decrypt_ccmp(frame.getlayer(Dot11), tk=b"\x00"*16)

ifplaintextisNone: returnFalse



# Wereceivedavalidplaintextframe!

log(STATUS,'Client encrypted a frame with an all-zero key!', color="green")

returnTrue

上面的测试用例将创建一个客户端能够连接的接入点。客户端连接后,它将向客户端发送4路握手消息。接下来,易受攻击的客户端将开始使用全零加密来密钥,随后测试用例将会自动检测到这一情况。

我们也可以使用模拟Wi-Fi来运行上述测试用例:

./setup/setup-hwsim.sh4

sourcesetup/venv/bin/activate

./run.pywlan1example-krack-zero-key

项目地址

Wi-Fi Framework:【​​GitHub传送门​​】

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/128696.html<

(0)
运维的头像运维
上一篇2025-02-25 06:39
下一篇 2025-02-25 06:40

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注