CHALLENGE ROOM
Lesson Learned?
data:image/s3,"s3://crabby-images/2f83d/2f83da063eb921d8f2c98c8629fada69bb73e1e8" alt="Room Icon"
Level:
EASY
Technology: Linux
Challenge Overview
This challenge presents a login page, which we must bypass to retrieve the flag. The challenge involves SQL Injection (SQLi), brute-forcing, and authentication bypass techniques.
Testing for SQL Injection
The first approach is to test basic SQL injection payloads in the username field. A common test payload is:
' OR 1=1 --
If the website is vulnerable, this payload should log us in as the first user in the database. However, instead of a successful login, we receive a custom error message from the challenge creator:
The challenge forces us to restart after each failed login attempt, making brute-force attacks inefficient.
Brute-Forcing the Username
Since SQLi alone does not work, we attempt brute-forcing the login page using Hydra to discover valid credentials.
However, by mistake, we use the RockYou wordlist for usernames instead of passwords, but surprisingly, it works.
hydra -L /usr/share/wordlists/rockyou.txt -p password -s 80 -f 10.10.229.198 http-post-form "/:username=^USER^&password=^PASS^:Invalid username and password."
Yes we use the rockyou.txt wordlist for usernames (it's a mistake, but it works). Finally, we find a valid username:
[80][http-post-form] host: 10.10.229.198 login: patrick password: password
We now have a valid username: patrick
.
Exploiting SQL Injection
With the username discovered, we attempt an authentication bypass using SQLi. We reference a well-known SQLi payload from Tib3rius' blog:
patrick' AND '1'='1' -- -
This allows us to bypass the login authentication, granting access to the system.
Retrieving the Flag
Upon successful authentication bypass, we obtain the flag and the lesson learned from the challenge.
🏆 Challenge Complete! 🚀