TyrHackMe | Light | Writeup
Welcome to the Light database application!
data:image/s3,"s3://crabby-images/e2e29/e2e296e9633ffac329069fc96587d3c83ffc029d" alt=""
Find This Room: Light
If you want to get the Answer directly
Light was a simple room where we exploited an SQL
injection in a SQLite
database to retrieve the credentials for the admin user and a flag.
Discovering the SQL Injection
As per the room instructions, after connecting to the service on port 1337
, we encounter a database application.
data:image/s3,"s3://crabby-images/82ca9/82ca9ec240a13e5c5bf690e5318ce782bf1f4bb1" alt=""
The room also instructs us to use the username smokey
to begin, and upon entering it, we retrieve the password for the user.
data:image/s3,"s3://crabby-images/d5224/d522455b6d18211b1643fbe024d6a0675fd2167d" alt=""
Since it is a database application, if we try a simple SQL
injection with '
, we see that it is successful as we get the error: Error: unrecognized token: "''' LIMIT 30"
.
data:image/s3,"s3://crabby-images/8633a/8633ab69f4a8eea208a93e8079e322b24b11bde2" alt=""
Trying a union-based injection and commenting out the ' LIMIT 30
part with --
, we encounter an interesting error stating that /*
, --
, or %0b
are not allowed.
data:image/s3,"s3://crabby-images/cc799/cc799edae1baf018487ea685336f6fc9eeaae605" alt=""
Instead of trying to comment out the last part due to the '
causing errors, since SELECT 1 ''
is a valid query, we can turn the query into UNION SELECT 1 '' LIMIT 30
by appending '
to our payload as ' UNION SELECT 1 '
. As we can see, this works, but this time we encounter an interesting error about certain words not being allowed.
data:image/s3,"s3://crabby-images/b6691/b6691661737ce51fe6a47192f95a776ba1a8e9f5" alt=""
It seems the UNION
and SELECT
keywords are not allowed, but we can easily bypass this filter by using capitalization
data:image/s3,"s3://crabby-images/56828/568284c4f9aedba53f70f06d666ec2456cc0439e" alt=""
As we can see now, with the payload ' Union Select 1 '
, we are successful with a union-based injection.
data:image/s3,"s3://crabby-images/e4f31/e4f3126fc4207df1f98f7284c54707d7aa744589" alt=""
Identifying the DBMS
With the union-based injection we have, if we attempt to identify the database management system, we discover it is SQLite
.
data:image/s3,"s3://crabby-images/077d6/077d6eeb883996d35f7f631f580d8dea2c1afb8b" alt=""
Dumping Database Structure
Now that we know the DBMS is SQLite
, we can use the payload ' Union Select group_concat(sql) FROM sqlite_master '
to extract the database structure, as shown below:
data:image/s3,"s3://crabby-images/57520/575208e618e91496e62ddf2a938ca2e44fd9cc99" alt=""
Extracting Data
Since our goal is to find the credentials for the admin user, we can dump the username
and password
fields from the admintable
using the payload ' Union Select group_concat(username || ":" || password) FROM admintable '
and this not only gives us the credentials but also the flag, allowing us to complete the room.
data:image/s3,"s3://crabby-images/accb1/accb1e9c4f8b7d5b4ce7a3e8bc9b8eae54ed81f2" alt=""
Follow Me : Linkedin , Facebook , Github , Join Us On Community , THM Account
data:image/s3,"s3://crabby-images/70d8b/70d8b6326f5fae1d4a823967b69db73016a4c49c" alt=""