SMSChallengeWrite-Up(Web)-CyCTF2024
 Omar Mohamed
Thanks for sharing!
بِسْمِ اللَّهِ الرَّحْمَنِ الرَّحِيمِ

Hello everyone! It's Omar (aka キ Mushroom).
Today, I’ll walk you through the write-up for the
Today, I’ll walk you through the write-up for the
SMS challenge from the CyCTF 2024 qualifications.This was a fun challenge that involved using SQL injection to create an account, followed by exploiting 
PHP filter chains to retrieve the flag.Here is the source code for the challenge: SMS Challenge - GitHub
Let's dive in!
Challenge Overview
We know that the flag is located at the 
We have both source code and access to a live server.
/flag.txt path.We have both source code and access to a live server.

Visiting the Website
When visiting the website, we see a page with a feedback form and an upload form:

Initially, I suspected a file upload vulnerability, but let’s check the source code provided to confirm.
Source Code Analysis
Here's a quick summary of the application files provided:

- index.php - Contains the two forms shown above.
- login.php - which seems secure to me, and notice the line $_SESSION['admin'] = true;whenever you succefully login 
- reset.php - Nothing unusual or exploitable.
- upload.php - Originally suspected of file upload vulnerability, but a closer code review shows it’s secure.
- forgot_password.php - Nothing exploitable here either.
Note: Since the source code is lengthy, I've attached it in a GitHub repo (link provided above) for reference.
Finding the SQL Injection Vulnerability
In 
submit_feedback.php, we notice something interesting
$date is passed without any validation, making it vulnerable to SQL injection.We control the
Date header through $_SERVER['HTTP_DATE'], which becomes our entry point.For our last 3 files: 
dashboard.php, feedback.php, and check_integrity.php require an admin session to access as shown belowWhich basically means we have to login somehow and we will have access to those routes, because you will get an 
admin session whenever you login as mentioned aboveExploiting the SQL Injection Vulnerability
Let’s start by crafting our SQL payload to create an account:
- Initial Injection: End the current query using:
- Insert New User: Knowing the usernameandpasswordcolumns in theuserstable, our query becomes: Here,#is used to comment out the rest of the query. However, this approach doesn’t work as expected.
Upon reviewing 
login.php, we see that it uses password_verify, meaning passwords are stored as hashed values.
Checking 
reset.php, we also find that passwords are hashed using password_hash.
To generate a hashed password, I ran the following PHP code:
Our final injection payload becomes:
This successfully adds a user named 
mushroom with the password pass.Executing the Injection
I submitted feedback with this payload using Burp Suite, injecting the crafted SQL in the 
The server response was a blank page, indicating that the injection succeeded.
Date header.The server response was a blank page, indicating that the injection succeeded.

Logging in as Admin
Navigating to 
login.php, I successfully logged in with the newly created credentials and was redirected to the dashboard.
Searching for Vulnerabilities
With admin access, I examined 
dashboard.php, feedback.php, and check_integrity.php. While the first two files didn’t reveal much, check_integrity.php seemed promising.Upon further inspection, it uses the 
sha1_file function, which can be exploited. A Google search for "sha1_file PHP vulnerability" led me to an article on PHP filter chains.Automating the PHP Filter Exploit
The article provides a tool to automate the exploit: synacktiv/php_filters_chain_oracle_exploit.
After installing, the command should end up looking like this:
Note that I added a dummy value for 
user_hash because it is required to enter the sha1_file function
Note: You may need to remove the SSL warning when running the tool.
To do that just add those lines at the beginning of this file: 
requestor.py in core directoryRetrieving the Flag
Running the exploit, we begin to see the flag appear, character by character.

After a while, we retrieve the complete flag:
CYCTF{tXv6lJDD-rtX_PC-TngDsrxpOP_mu7As6UaEO5Gmhk0Fo5WYO9S_aIzPiiDxj_yVYnsZxfgK8F9TGyy7zC19R_aGMJAPKXaAYnLUCAnBf96i}
Note: The last 
} might not appear due to truncation; add it manually.That's all!
Hope you enjoyed the write-up. It was fun solving this challenge.
Check out my X (formerly Twitter) for more updates.
You can find me on Discord: 
mush.shCheck out my other write-up on Vending Machine Challenge
Peace!
Tags:

