skills/code-audit/php/php-injection-audit/SKILL.md
PHP 源码注入类漏洞审计。当在 PHP 白盒审计中需要检测注入类漏洞时触发。 覆盖 6 种注入: SQL 注入(PDO/MySQLi/ORM)、NoSQL 注入(MongoDB)、 命令注入(system/exec/passthru)、LDAP 注入、表达式注入(eval/preg_replace /e)、SSRF。 需要 php-audit-pipeline 提供的数据流证据(EVID_*)作为审计输入。
npx skillsauth add wgpsec/AboutSecurity php-injection-auditInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
本 skill 聚焦源码层面判断"注入是否成立",核心是验证 Source→Sink 路径上的过滤是否充分。构造 payload、绕 WAF 等运行时利用技术属于对应黑盒 exploit skill 范畴。
| 类型 | 典型 Sink | 危险模式 | 严重度 |
|------|-----------|----------|--------|
| SQL 注入 | PDO::query, mysqli_query, DB::raw, whereRaw | 字符串拼接进 SQL | Critical-High |
| 命令注入 | exec, system, shell_exec, passthru, proc_open, 反引号 | 用户输入拼入命令串 | Critical |
| SSRF | curl_exec, file_get_contents, SoapClient | 用户可控 URL 发起服务端请求 | High-Medium |
| 表达式注入 | eval, assert, preg_replace(/e), create_function | 用户输入进入代码执行上下文 | Critical |
| NoSQL 注入 | MongoDB find(), $where, 操作符 $ne/$gt/$regex | 数组/对象参数绕过等值比较 | High |
| LDAP 注入 | ldap_search, ldap_list, ldap_bind | 用户输入拼入过滤器字符串 | High-Medium |
Step 1 -- 确认 EVID 证据点: 从 php-audit-pipeline Phase 3 产出的 EVID_* 证据中,筛选属于注入类的条目(EVID_SQL_、EVID_CMD_、EVID_SSRF_、EVID_EXPR_、EVID_LDAP_*)。没有 EVID 证据的 Sink 只能标"待验证"。
Step 2 -- 判断过滤有效性: 追踪 Source→Sink 路径上的每一步过滤/转义操作,评估其是否对当前注入类型有效。常见陷阱: addslashes 对 GBK 宽字节无效、intval 对数组参数无效、escapeshellarg 在特定 locale 下可绕过。
Step 3 -- 评估绕过可能性: 过滤存在但不充分时,分析具体绕过路径(编码差异、类型混淆、二次处理等)。能给出绕过思路则标"已确认",否则标"待验证"并记录已知过滤方式。
Step 4 -- 确定严重度: 使用 php-audit-pipeline 的三维度评分公式 Score = R*0.40 + I*0.35 + C*0.25。注入类漏洞的 Impact 通常较高(命令/表达式注入 I=3, SQL 注入 I=2-3),但需结合可达性和利用复杂度综合判断。
prepare() + execute() 的占位符绑定完整。PDO::query($sql) 和 PDO::exec($sql) 是直接执行,拼接即危险whereRaw/havingRaw/orderByRaw/selectRaw 中的变量拼接不受 ORM 参数化保护intval() 或白名单是唯一安全方案sprintf("SELECT * FROM t WHERE id='%s'", $input) 本质仍是拼接escapeshellcmd 同时使用反而会引入绕过(引号配对被破坏)exec("convert " . escapeshellarg($src) . " " . $dest) — 如果 $dest 未转义则仍可注入proc_open([$cmd, $arg1, $arg2], ...) 避免了 shell 解析,是安全的命令执行方式http/https 以外的协议(gopher:// 可打内网服务,file:// 可读本地文件)2130706433、八进制 0177.0.0.1、IPv6 [::1]、DNS Rebinding 都能绕过简单的 IP 检查curl 默认不跟随但 CURLOPT_FOLLOWLOCATION=true 时,可通过 302 跳转绕过 URL 白名单eval() 都是 Critical。assert() 在 PHP < 8.0 可执行字符串preg_replace_callback 是安全的eval,PHP 8.0 已移除但老项目常见array_map/usort/call_user_func 的回调参数如果用户可控,等价于代码执行$_GET['user'][$ne]=1 可绕过等值匹配,检查是否对输入做了类型强制转换$where 接受 JavaScript 表达式,用户可控时等价于代码执行(&(uid=$input)(pass=$pass)) 中注入 *)(uid=*))(|(uid=* 可修改查询逻辑ldap_escape() 但很多项目未使用,检查 (, ), *, \, NUL 是否被转义testing
Azure 云环境渗透测试总体方法论。当目标使用 Azure/Microsoft 365/Entra ID、发现 Azure 相关资产(Blob Storage/App Service/Azure VM/Azure Functions)、获取 Azure 凭据(Service Principal/Managed Identity/Access Token)、或需要对 Azure 环境进行安全评估时使用。提供从未授权枚举到 Entra ID 攻击、服务提权、Cloud-to-OnPrem 横向移动的全流程决策树。覆盖 35+ Azure 服务攻击面
tools
Mythic C2 操作方法论。当需要部署 Mythic、选择 Mythic Agent、安装 C2 Profile、配置 HTTP/DNS/WebSocket/SMB/TCP 通信、生成 payload、管理回连任务,或把 Mythic 作为跨平台 C2 框架用于授权红队演练时使用。覆盖 mythic-cli 安装、Agent/Profile 选择、SSL 证书配置、payload 构建和基础 OPSEC 判断
development
Docker 安全测试与容器渗透方法论。当需要评估 Docker 容器、Docker Daemon、Docker Registry、镜像层、构建产物或容器逃逸风险时使用。覆盖容器环境识别、特权容器逃逸、docker.sock/Remote API 利用、procfs/cgroup/capabilities 滥用、Docker 用户组提权、运行时/内核 CVE、Registry 枚举、镜像层 Secret 分析和构建上下文泄露。发现 Docker 容器环境、Registry 暴露、镜像凭据或容器配置错误时应使用此技能
development
使用 PadBuster 进行 Padding Oracle 攻击。当发现 Web 应用使用 CBC 模式加密且存在 Padding Oracle 漏洞时使用。PadBuster 可自动解密密文和伪造任意明文对应的合法密文,适用于加密 Cookie/Token/URL 参数。任何涉及 Padding Oracle 攻击、CBC 密文解密、Cookie 伪造的场景都应使用此技能