GoTestWAF是一款API和OWASP***模拟工具,支持REST、GraphQL、gRPC、SOAP、XMLRPC等多种API协议。它专为评估Web应用安全解决方案而设计,如API安全代理、Web应用防火墙(WAF)、入侵防御系统(IPS)、API网关等。
GoTestWAF通过在HTTP请求的不同部分(如请求体、头、URL参数等)植入编码后的负载来生成请求。生成的请求会发送到启动时指定的应用安全解决方案URL。安全解决方案的评估结果将记录在本地生成的报告文件中。
请求生成的默认条件定义在testcases文件夹的YAML文件中,格式如下:
yamlpayload: - '"union select -7431.1, name, @aaa from u_base--w-' - "'or 123.22=123.22" - "' waitfor delay '00:00:10'--" - "')) or pg_sleep(5)--" encoder: - Base64Flat - URL placeholder: - UrlPath - UrlParam - JSUnicode - Header type: SQL Injection
payload:******样本(例如XSS负载<script>alert(111)</script>或更复杂的内容)。由于YAML字符串格式要求,负载必须以二进制数据形式编码。
encoder:负载植入HTTP请求前应用的编码器。支持的编码器包括:
placeholder:编码后负载在HTTP请求中的位置。支持的位置包括:
RawRequest占位符允许自定义HTTP请求,通过替换URL路径、头或体中的{{payload}}字符串植入负载。RawRequest的必填字段:
method示例:
yamlpayload: - test encoder: - Plain placeholder: - RawRequest: method: "POST" path: "/" headers: Content-Type: "multipart/form-data; boundary=boundary" body: | --boundary Content-disposition: form-data; name="field1" Test --boundary Content-disposition: form-data; name="field2" Content-Type: text/plain; charset=utf-7 Knock knock. {{payload}} --boundary-- type: RawRequest test
type:负载组的***类型名称(例如SQL Injection)。
以下步骤介绍如何通过Docker下载并启动GoTestWAF的最小配置。
从Docker Hub拉取GoTestWAF镜像:
docker pull wallarm/gotestwaf
启动GoTestWAF镜像:
shdocker run --rm --network="host" -it -v ${PWD}/reports:/app/reports \ wallarm/gotestwaf --url=<被评估安全解决方案URL>
可将${PWD}/reports替换为存放评估报告的其他目录路径。
若不需要通过邮件发送报告,可在出现邮件请求提示时按Enter,或使用--noEmailReport跳过提示:
shdocker run --rm --network="host" -v ${PWD}/reports:/app/reports \ wallarm/gotestwaf --url=<被评估安全解决方案URL> --noEmailReport
若被评估安全工具可从外部访问,可省略--network="host"选项。该选项用于实现运行在127.0.0.1上的Docker容器间交互。
执行gRPC测试需指定工作端点并使用--grpcPort <端口>选项:
shdocker run --rm --network="host" -it -v ${PWD}/reports:/app/reports \ wallarm/gotestwaf --grpcPort 9000 --url=[***]
查收邮件中的报告。
已通过最小配置使用GoTestWAF完成应用安全解决方案评估。高级配置选项详见配置选项。
通过STDOUT和STDERR查看评估结果日志。示例:
INFO[0000] GoTestWAF started version=v0.5.6-7-g48e6959 INFO[0000] Test cases loading started INFO[0000] Test cases loading finished INFO[0000] Test cases fingerprint fp=c6d14d6138601d19d215bb97806bcda3 INFO[0000] Try to identify WAF solution INFO[0000] WAF was not identified INFO[0000] gohttp is used as an HTTP client to make requests http_client=gohttp INFO[0000] WAF pre-check url="[***]" INFO[0000] WAF pre-check blocked=true code=403 status=done INFO[0000] gRPC pre-check status=started INFO[0000] gRPC pre-check connection="not available" status=done INFO[0000] GraphQL pre-check status=started INFO[0000] GraphQL pre-check connection="not available" status=done INFO[0000] Scanning started url="[***]" INFO[0005] Scanning finished duration=5.422700876s True-Positive Tests: ┌────────────┬───────────────────────────┬──────────────────────┬─────────────────────┬──────────────────────┬────────────────────┬─────────────┬─────────────────┐ │ TEST SET │ TEST CASE │ PERCENTAGE , % │ BLOCKED │ BYPASSED │ UNRESOLVED │ SENT │ FAILED │ ├────────────┼───────────────────────────┼──────────────────────┼─────────────────────┼──────────────────────┼────────────────────┼─────────────┼─────────────────┤ │ community │ community-128kb-rce │ 0.00 │ 0 │ 0 │ 1 │ 1 │ 0 │ │ community │ community-128kb-sqli │ 0.00 │ 0 │ 0 │ 1 │ 1 │ 0 │ │ community │ community-128kb-xss │ 0.00 │ 0 │ 0 │ 1 │ 1 │ 0 │ │ community │ community-16kb-rce │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-16kb-sqli │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-16kb-xss │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-32kb-rce │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-32kb-sqli │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-32kb-xss │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-64kb-rce │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-64kb-sqli │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-64kb-xss │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-8kb-rce │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-8kb-sqli │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-8kb-xss │ 100.00 │ 1 │ 0 │ 0 │ 1 │ 0 │ │ community │ community-lfi │ 100.00 │ 8 │ 0 │ 0 │ 8 │ 0 │ │ community │ community-lfi-multipart │ 0.00 │ 0 │ 0 │ 2 │ 2 │ 0 │ │ community │ community-rce │ 50.00 │ 2 │ 2 │ 0 │ 4 │ 0 │ │ community │ community-rce-rawrequests │ 100.00 │ 3 │ 0 │ 0 │ 3 │ 0 │ │ community │ community-sqli │ 100.00 │ 12 │ 0 │ 0 │ 12 │ 0 │ │ community │ community-user-agent │ 66.67 │ 6 │ 3 │ 0 │ 9 │ 0 │ │ community │ community-xss │ 88.46 │ 92 │ 12 │ 0 │ 104 │ 0 │ │ community │ community-xxe │ 0.00 │ 0 │ 1 │ 1 │ 2 │ 0 │ │ owasp │ crlf │ 85.71 │ 6 │ 1 │ 0 │ 7 │ 0 │ │ owasp │ ldap-injection │ 8.33 │ 2 │ 22 │ 0 │ 24 │ 0 │ │ owasp │ mail-injection │ 12.50 │ 3 │ 21 │ 0 │ 24 │ 0 │ │ owasp │ nosql-injection │ 24.00 │ 12 │ 38 │ 0 │ 50 │ 0 │ │ owasp │ path-traversal │ 30.00 │ 6 │ 14 │ 0 │ 20 │ 0 │ │ owasp │ rce │ 33.33 │ 2 │ 4 │ 0 │ 6 │ 0 │ │ owasp │ rce-urlparam │ 33.33 │ 3 │ 6 │ 0 │ 9 │ 0 │ │ owasp │ rce-urlpath │ 0.00 │ 0 │ 3 │ 0 │ 3 │ 0 │ │ owasp │ shell-injection │ 18.75 │ 6 │ 26 │ 0 │ 32 │ 0 │ │ owasp │ sql-injection │ 29.17 │ 14 │ 34 │ 0 │ 48 │ 0 │ │ owasp │ ss-include │ 50.00 │ 12 │ 12 │ 0 │ 24 │ 0 │ │ owasp │ sst-injection │ 29.17 │ 7 │ 17 │ 0 │ 24 │ 0 │ │ owasp │ xml-injection │ 0.00 │ 0 │ 7 │ 0 │ 7 │ 0 │ │ owasp │ xss-scripting │ 39.91 │ 89 │ 134 │ 1 │ 224 │ 0 │ │ owasp-api │ graphql │ 0.00 │ 0 │ 0 │ 0 │ 0 │ 0 │ │ owasp-api │ graphql-post │ 0.00 │ 0 │ 0 │ 0 │ 0 │ 0 │ │ owasp-api │ grpc │ 0.00 │ 0 │ 0 │ 0 │ 0 │ 0 │ │ owasp-api │ non-crud │ 100.00 │ 2 │ 0 │ 0 │ 2 │ 0 │ │ owasp-api │ rest │ 42.86 │ 3 │ 4 │ 0 │ 7 │ 0 │ │ owasp-api │ soap │ 20.00 │ 1 │ 4 │ 0 │ 5 │ 0 │ ├────────────┼───────────────────────────┼──────────────────────┼─────────────────────┼──────────────────────┼────────────────────┼─────────────┼─────────────────┤ │ Date: │ Project Name: │ True-Positive Score: │ Blocked (Resolved): │ Bypassed (Resolved): │ Unresolved (Sent): │ Total Sent: │ Failed (Total): │ │ 2025-07-14 │ generic │ 45.36% │ 303/668 (45.36%) │ 365/668 (54.64%) │ 7/675 (1.04%) │ 675 │ 0/675 (0.00%) │ └────────────┴───────────────────────────┴──────────────────────┴─────────────────────┴──────────────────────┴────────────────────┴─────────────┴─────────────────┘ True-Negative Tests: ┌────────────┬───────────────┬──────────────────────┬─────────────────────┬──────────────────────┬────────────────────┬─────────────┬─────────────────┐ │ TEST SET │ TEST CASE │ PERCENTAGE , % │ BLOCKED │ BY
来自真实用户的反馈,见证轩辕镜像的优质服务
免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
在 Linux 系统配置镜像加速服务
在 Docker Desktop 配置镜像加速
Docker Compose 项目配置加速
Kubernetes 集群配置 Containerd
在宝塔面板一键配置镜像加速
Synology 群晖 NAS 配置加速
飞牛 fnOS 系统配置镜像加速
极空间 NAS 系统配置加速服务
爱快 iKuai 路由系统配置加速
绿联 NAS 系统配置镜像加速
QNAP 威联通 NAS 配置加速
Podman 容器引擎配置加速
HPC 科学计算容器配置加速
ghcr、Quay、nvcr 等镜像仓库
无需登录使用专属域名加速