跳转到帖子

游客您好,欢迎来到黑客世界论坛!您可以在这里进行注册。

赤队小组-代号1949(原CHT攻防小组)在这个瞬息万变的网络时代,我们保持初心,创造最好的社区来共同交流网络技术。您可以在论坛获取黑客攻防技巧与知识,您也可以加入我们的Telegram交流群 共同实时探讨交流。论坛禁止各种广告,请注册用户查看我们的使用与隐私策略,谢谢您的配合。小组成员可以获取论坛隐藏内容!

TheHackerWorld官方

WAF-A-MoLE:针对Web应用防火墙的基于变异的模糊测试工具

精选回复

发布于

WAF-A-MoLE:针对Web应用防火墙的基于变异的模糊测试工具

6126f5d34c68a.jpg

关于WAF-A-MoLE

WAF-A-MoLE是一款功能强大的基于变异的模糊测试工具,该工具可以帮助广大研究人员对基于ML的Web应用防火墙进行模糊测试。

只需提供一条SQL注入查询语句,该工具便能够尝试生成一个可绕过目标WAF的语义不变的变种查询。我们可以使用WAF-A-MoLE来探索解决方案空间,找到目标分类器未发现的危险“盲点”,并且可以使用此工具评估产品的稳健性。

工具体系架构

1629524541_6120923d1d4ab7b56a101.png!sma

WAF-A-MoLE可以获取初始Payload并将其插入Payload池中,Payload池将负责管理一个Payload优先级队列。

在每次迭代过程中,Payload池的头部会被传递给模糊。在模糊器中,通过应用一个可用的变异操作符,对Payload池进行随机变异。

变异操作

变异操作都是语义保留的,它们利用了SQL语言(在这个版本中是MySQL)的高表达能力。

以下是当前版本WAF-A-MoLE中可用的变异操作:

变异样例
大小写切换admin' OR 1=1# ⇒ admin' oR 1=1#
空格替换admin' OR 1=1# ⇒ admin'\t\rOR\n1=1#
注释注入admin' OR 1=1# ⇒ admin'/**/OR 1=1#
注释重写admin'/**/OR 1=1# ⇒ admin'/*xyz*/OR 1=1#abc
整型编码admin' OR 1=1# ⇒ admin' OR 0x1=(SELECT 1)#
操作切换admin' OR 1=1# ⇒ admin' OR 1 LIKE 1#
逻辑恒量admin' OR 1=1# ⇒ admin' OR 1=1 AND 0<1#

工具要求

numpy

keras

scikit-learn

joblib

sqlparse

networkx

Click

工具下载&安装

广大研究人员可以使用下列命令将该项目源码克隆至本地:

git clone https://github.com/AvalZ/WAF-A-MoLE.git

然后运行下列命令完成依赖组件的安装:

pip install -r requirements.txt

工具使用

wafamole --help

Usage: wafamole [OPTIONS] COMMAND [ARGS]...

 

Options:

  --help  Show this message and exit.

 

Commands:

  evade  Launch WAF-A-MoLE against a target classifier.

wafamole evade --help

Usage: wafamole evade [OPTIONS] MODEL_PATH PAYLOAD

 

  Launch WAF-A-MoLE against a target classifier.

 

Options:

  -T, --model-type TEXT     Type of classifier to load

  -t, --timeout INTEGER     Timeout when evading the model

  -r, --max-rounds INTEGER  Maximum number of fuzzing rounds

  -s, --round-size INTEGER  Fuzzing step size for each round (parallel fuzzing

                            steps)

  --threshold FLOAT         Classification threshold of the target WAF [0.5]

  --random-engine TEXT      Use random transformations instead of evolution

                            engine. Set the number of trials

  --output-path TEXT        Location were to save the results of the random

                            engine. NOT USED WITH REGULAR EVOLUTION ENGINE

  --help                    Show this message and exit.

性能评估

1629524598_61209276f069a5eab26cd.png!sma

项目地址

WAF-A-MoLE:【GitHub传送门】

本文作者:Alpha_h4ck, 转载请注明来自FreeBuf.COM

创建帐户或登录后发表意见

最近浏览 0

  • 没有会员查看此页面。