PortSwigger's "High-level logic vulnerability" Walkthrough
This post is a walkthrough for the “high-level logic vulnerability” lab from PortSwigger Academy. For this walkthrough, you’ll need to have Burp Suite set up, as well as a Portswigger Academy account.
Log in to your Academy account and then view the lab at https://portswigger.net/web-security/logic-flaws/examples/lab-logic-flaws-high-level
. This is accessible from the “all labs” view or from the Business Logic Flaws page.
Challenge Information
data:image/s3,"s3://crabby-images/20f4d/20f4d39a2e276cd634b2e0f3782afef1729057c7" alt=""
Click the “Access the Lab” button and you will be taken to a temporary website that is created for your account. This will be in format https://<random string here>.web-security-academy.net/
.
This lab requires us to buy a “l33t” jacket. I had a hard time finding a definition for “high-level logic vulnerability” anywhere but I think it means an architectural flaw vs a single-point failure.
If we open up the site, it looks like this:
data:image/s3,"s3://crabby-images/b16f2/b16f2c3fd56f19f684a989b7d57561c3576a72c5" alt=""
If we login and then try to buy the “l33t” jacket:
data:image/s3,"s3://crabby-images/80bcc/80bcc115534bbb1c4824535e575c775af49627d3" alt=""
We’re unable to, because we only have $100 in credits.
If we look at the request in Burp Suite, there’s a redirect value:
data:image/s3,"s3://crabby-images/9a3a3/9a3a31ce6d2ba30a50a77681f28c6e75aa818f40" alt=""
I tried buying a cheaper item to see if I could find another valid redirect value that would let us bypass the check:
data:image/s3,"s3://crabby-images/f80b9/f80b9e10c472a8c4c68742e32682b02adaad7c64" alt=""
Unfortunately this didn’t work out. None of the other requests have anything interesting that we can control, except the request that corresponds to removing the “l33t” jacket from our cart:
data:image/s3,"s3://crabby-images/455d3/455d376a0eab69fff82bf1924e7b970c2a3a329a" alt=""
We can send the request to the Burp Suite repeater, and then modify the negative value:
data:image/s3,"s3://crabby-images/737b6/737b64204bf3be011eee625bdb14b64cc2e3d895" alt=""
This will cause us to end up with a negative quantity of coats and a huge negative value for our total:
data:image/s3,"s3://crabby-images/8a9bd/8a9bd4ab495263734b5a7f2b8ea312445b2cbf62" alt=""
But if we try to Place order
with these values, we get an error:
data:image/s3,"s3://crabby-images/61790/617905cd712d777d8be3a0fcc8dbdfe39960e556" alt=""
Lab Solution
Negative values of a product are fine, but negative dollar amounts for the total value are not fine.
What if we have a negative amount of one product (and negative dollar amount resulting from that), plus the $1337.00 cost of the “l33t” jacket, as long as it equals a positive value, under $100?
Add a single “l33t” jacket to your cart, then add another item, such as “Giant Pillow Thing”. Then remove that item (the point of this is to get a Burp Suite request that we can modify).
Then, in Burp Suite, modify the request to be a negative quantity and send it, so that you end up with a negative number of the non-jacket item:
data:image/s3,"s3://crabby-images/ca589/ca58943d3f990659913445f3e7b2a6e64efc6249" alt=""
Adjust this until you get a total amount that is less than your store credit amount:
data:image/s3,"s3://crabby-images/7b67d/7b67d3f50aca5f51e8421e899ee363046fa46629" alt=""
Then Place Order
, and the lab is complete!
data:image/s3,"s3://crabby-images/bfc2e/bfc2e92ac1c23b1dc90fec9056234fccca419fd6" alt=""
This was possible because the application allowed negative numbers of individual products, and only checked the overall result.