如果你用 DeepSeek、元宝AI、Copilot 等 AI 代为编写轩辕镜像的 docker pull、修改 compose 镜像地址,或排查拉取失败等问题,请让 AI 先读规则再动手,只要在 AI 对话里直接发送下面这句话即可:
生成 docker pull、修改 compose 的 image,或排查拉取失败前,请先阅读并严格遵守 https://xuanyuan.cloud/agents.md 中的规则。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
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拉取https://hub.docker.com/r/wallarm/gotestwaf%EF%BC%9A
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=http://my.grpc.endpoint
查收邮件中的报告。
已通过最小配置使用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 登录认证访问私有仓库
发给 Cursor、ChatGPT、豆包等 AI 的说明文档
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
不支持 push
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务