PortSwigger's "User role controlled by request parameter" Walkthrough
This blog post is for the first Apprentice-level “user role” lab within Portswigger’s Access Control lab category.
Before we get started, you’ll need a Portswigger Academy account. Log in and then view the lab at https://portswigger.net/web-security/access-control/lab-user-role-controlled-by-request-parameter
. This is accessible from the “all labs” view.
Challenge Information
data:image/s3,"s3://crabby-images/30e4e/30e4e348123af9677efb310e1a95ef29c5b8e6b3" 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 challenge once again has us trying to get admin access and delete Carlos’ account. The trick here is a forgeable cookie.
The website is the usual shopping site:
data:image/s3,"s3://crabby-images/55865/5586589009366a0c0b9acd20dc69b4c85fa96dbe" alt=""
If we go to /admin
, we get a message that we’re not allowed to access the controls as a non-admin user.
data:image/s3,"s3://crabby-images/bfe9d/bfe9d1e04270bdda22a20bc54c5631baa6b7783d" alt=""
Let’s try logging in with the provided credentials of wiener:peter
after clicking “My account”:
data:image/s3,"s3://crabby-images/f143f/f143f9874dc5c6e0fa822793b470fbbb0544da8e" alt=""
Now that we’re logged in, we should have some kind of session cookie.
Open up Dev Tools and go to Storage (Firefox) or Application (Chrome/others) to view cookies. We see that there’s a admin
cookie with value set to false
.
data:image/s3,"s3://crabby-images/c34bb/c34bbcc3416a8e5a2bdeb3d2c107ff1ef5e1e7e5" alt=""
Lab Solution
To solve this lab, we simply have to change the value to true
. You can do this within Dev Tools, by double-clicking and changing the value:
data:image/s3,"s3://crabby-images/d5fa0/d5fa0b4e8a198d3eecf139614649ba5d6c42a965" alt=""
You can also alter it in Burp Suite by sending the request to the Repeater
, finding the cookie value and setting it to true:
data:image/s3,"s3://crabby-images/ce0ac/ce0acac35aba314933f733bfe7b500e3acdc62c9" alt=""
Either way, you can now access the admin panel:
data:image/s3,"s3://crabby-images/bf2d5/bf2d51daf9d9acea2e5e5a83ff4aed8c5662f059" alt=""
And can delete Carlos’ account to solve the challenge:
data:image/s3,"s3://crabby-images/2a7c1/2a7c140b895b40b35a9e3c4483a6306154ce4b5e" alt=""