前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >WAF-A-MoLE:针对Web应用防火墙的基于变异的模糊测试工具

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

作者头像
FB客服
发布2021-09-16 10:33:07
4030
发布2021-09-16 10:33:07
举报
文章被收录于专栏:FreeBufFreeBuf

关于WAF-A-MoLE

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

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

工具体系架构

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

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

变异操作

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

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

工具要求

numpy keras scikit-learn joblib sqlparse networkx Click

工具下载&安装

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

代码语言:javascript
复制
git clone https://github.com/AvalZ/WAF-A-MoLE.git

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

代码语言:javascript
复制
pip install -r requirements.txt

工具使用

wafamole —help

代码语言:javascript
复制
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

代码语言:javascript
复制
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.

性能评估

项目地址:点击底部【阅读原文】获取

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-08-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 FreeBuf 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 关于WAF-A-MoLE
  • 工具体系架构
  • 变异操作
  • 工具要求
  • 工具下载&安装
  • 工具使用
    • wafamole —help
      • wafamole evade —help
      • 性能评估
      相关产品与服务
      云数据库 MySQL
      腾讯云数据库 MySQL(TencentDB for MySQL)为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。其具备6大企业级特性,包括企业级定制内核、企业级高可用、企业级高可靠、企业级安全、企业级扩展以及企业级智能运维。通过使用腾讯云数据库 MySQL,可实现分钟级别的数据库部署、弹性扩展以及全自动化的运维管理,不仅经济实惠,而且稳定可靠,易于运维。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档