XML INJECTION
- Layout for this exercise:
data:image/s3,"s3://crabby-images/431b7/431b79fc000cfabeafa8dbb201c8ab01eefc5b41" alt=""
1 - Introduction
- An XML (Extensible Markup Language) database is a data persistence software system that allows data to be specified, stored and retrieved in XML format.
https://en.wikipedia.org/wiki/XML_database
- This data can be queried, transformed, exported and returned to a calling system.
- XML databases are a flavor of document-oriented databases which are in turn a category of NoSQL database.
- When the data in a website is stored in a XML database, then this data is accessed by using a method known as XPath query generation.
- In this method, an XPath query is generated after the user provides the input to the system and the required data is accessed.
- The problem arises when the input provided by the user is not properly filtered or validated by the system.
- The prevention of XML injection can be done by properly managing and sanitizing any user input before it is allowed to reach the main program code.
https://blog.udemy.com/xml-injection/
- The best method is to consider all the user input as unsafe and to properly monitor this input.
- Most types of the XML injection attacks can be prevented by simply removing all the single and double quotes from the user input.
2 - XML injection scenario
- In this exercise the OWASP WebGoat v5.4 version is used, loaded at the Windows 10 machine:
- Going to AJAX Security -> XML Injection:
data:image/s3,"s3://crabby-images/42951/42951d6acc8898defeb1896667aa5b006042c4cb" alt=""
- The scenario of this exercise consists of a web application that offers rewards based on the number of points accumulated by the user.
- In particular, the user whose account has the ID 836239 holds a balance of 100 points, enough to get the first three products from the following list (note that the last two products require a number of points much higher than the 100 available):
data:image/s3,"s3://crabby-images/6cd58/6cd58abf3bc9211c7ee9430772d96847b4e828d6" alt=""
- By entering the user ID, the three products will be sent to the user's address:
data:image/s3,"s3://crabby-images/207ca/207cab9dcfaa7f8e16a0b9f90b9d04dcb7ccad04" alt=""
data:image/s3,"s3://crabby-images/ec767/ec767265f7ad0cd54ff64dc32628df51b8b41d08" alt=""
- The XML file that stores such information about the user is the following:
data:image/s3,"s3://crabby-images/6743a/6743a44705aba3e0f3ef73a8bc8c1a4eb43f91fc" alt=""
- Regarding the rewards:
data:image/s3,"s3://crabby-images/d8f7a/d8f7aab49621061fb165d1718b215fd1bb46e92a" alt=""
- The first XPATH query to fetch the user corresponding to the entered ID would be:
data:image/s3,"s3://crabby-images/dec0c/dec0ca1c39270658413e5ea7f2c8d574b9641ef0" alt=""
- The second XPATH query to detect the records of gifts with less than 100 points would be:
data:image/s3,"s3://crabby-images/6d1b8/6d1b820dc11fdf92ec2433d99c72a668a5585f74" alt=""
3 - Launching the XML injection
- Using the browser Firefox, enabling the Proxy server at Kali Linux:
data:image/s3,"s3://crabby-images/6f8e7/6f8e704caaa0c9973957d9f220b30bcd25fd4b35" alt=""
- Enabling Burp interception at Kali Linux, for requests and responses between the attacker and the victim:
data:image/s3,"s3://crabby-images/cd345/cd345781f98768a798dc0a17d1e385512268d233" alt=""
- The user tries to use his points:
data:image/s3,"s3://crabby-images/31f23/31f23ef731157c186fee550e84cb69bfe10f9f1c" alt=""
- Forwarding with Burp:
data:image/s3,"s3://crabby-images/51b2b/51b2ba23e508da698b8ddbfe64899514c2c64ef3" alt=""
- Intercepting the answer:
data:image/s3,"s3://crabby-images/3aabd/3aabda7e18017e8c502c57f5c2479a457f008dec" alt=""
data:image/s3,"s3://crabby-images/cbd4a/cbd4abc8105a8860814c55cf72eea5b590fcc25a" alt=""
- Now, the response is altered injecting these two extra lines, or two extra XML nodes, including the max rewards of 2000 and 3000 points, respectively:
data:image/s3,"s3://crabby-images/a26b5/a26b5867f9e6ea4ee463b4fa4d2e756fb6ff69f2" alt=""
- Forwarding with Burp:
data:image/s3,"s3://crabby-images/aba19/aba196b9bf535776e49d12aaae8e40dd9f295f4e" alt=""
- The user receives the option to adquire all the items, though he has not got enough points for it:
data:image/s3,"s3://crabby-images/13272/1327237b1bb96d2eb36194c5862f6d8db6c7baaf" alt=""
- Checking the rewards and Submitting a new request:
data:image/s3,"s3://crabby-images/74d49/74d49e6de773cfbc3f41fa940f904f949872dbeb" alt=""
- The XML injection is successful (the five items are shipped to the user's address) because the server has not properly validated the request:
data:image/s3,"s3://crabby-images/e7fc3/e7fc34eae41d8bd522a9758288df366e344c0989" alt=""
data:image/s3,"s3://crabby-images/94ac2/94ac2cf8e964c605a81f48dbc2713ef06d42eaf9" alt=""