SQL INJECTION - BLIND (II): TIME DELAY BASED ATTACKS
- Layout for this exercise:
data:image/s3,"s3://crabby-images/e5f2e/e5f2e81104fc8aeed0df93bcf411b7fb42bbdf7e" alt=""
1 - Introduction
https://www.owasp.org/index.php/Testing_for_SQL_Injection_(OTG-INPVAL-005)#Time_delay_Exploitation_technique
- This type of attack uses database commands like sleep() or benchmark() to delay answers in conditional queries.
- sleep(time) suspends the execution of a command for time seconds.
- benchmark(count, expression) repeatedly executes an expression by count times
- This attack would be useful when the attacker doesn’t have any kind of answer (result / output / error) from the application because the input validation has been sanitized.
- Using this method an attacker could enumerate many elements of the database.
- For instance, using sleep(10) and a conditional loop for the 1st letter of the database's being 'A', if the answer comes after 10 seconds, we can conclude that the condition is true; otherwise the application would not respond
2 - Examples of Time Delay Blind SQL injection
- These SQL injection time delay based exercises will be performed from a Kali Linux device against a DVWA version 1.0.8 MySQL database, with a setup of "medium"security level, stored at an Ubuntu Linux device running the XAMPP web server.
data:image/s3,"s3://crabby-images/74df1/74df174cc7c6c2ae0012136948a980aba6dc24e7" alt=""
data:image/s3,"s3://crabby-images/eeb03/eeb039756b618501621ace6d78d5d061823f646e" alt=""
data:image/s3,"s3://crabby-images/fabdf/fabdfe0fd8e68c79bc92ca45c78d77e484fa0040" alt=""
- Going to the SQL Injection (Blind) tab, the following SQL entries (written in green) will be introduced at the user ID form.
data:image/s3,"s3://crabby-images/d7c40/d7c4072581bf656f6ffdc002bbd72102ef4f163b" alt=""
2.1) Finding whether the application is responsive to time based attacks
1 UNION SELECT IF (1=1, SLEEP(10), NULL), NULL
data:image/s3,"s3://crabby-images/8ee7f/8ee7f766abdb0a313ae00a37b46d604902aeb341" alt=""
- Let's notice the Connecting notification lasting for 10 seconds, so we can conclude that te application is responsive to this type of attack:
data:image/s3,"s3://crabby-images/9e185/9e185e6b7894dd0651fb12983afdc43dbc6cec84" alt=""
data:image/s3,"s3://crabby-images/64a4c/64a4c419b839f91109b7df301e79d87f757aca19" alt=""
- The real SQL query would be:
SELECT first_name,last_name FROM users WHERE ID=1
UNION
SELECT IF (1=1,SLEEP(10),NULL),NULL
2.2) Finding whether the database version is 5
1 UNION SELECT IF (SUBSTRING(VERSION), 1, 1) = 5, SLEEP(10), NULL), NULL
data:image/s3,"s3://crabby-images/4546b/4546bf0dcabcc8230893c22a52bfa9ae5a366032" alt=""
- Again, the result is obtained after waiting for 10 seconds:
data:image/s3,"s3://crabby-images/c4a64/c4a64a84fda807d8ef78d0009786be43f5d211fe" alt=""
data:image/s3,"s3://crabby-images/e6f38/e6f38e0d66d2422fbf125b87a6e0ca979c828917" alt=""
- We can conclude that the version is actually 5 (conditional loop) because there is no error message answer and the query injection is successful.
- The real SQL query would be:
SELECT first_name,last_name FROM users WHERE ID=1
UNION
SELECT IF (SUBSTRING(version(),1,1)=5, SLEEP(10),NULL),NULL
- The second part of the command consists of IF(condition, true statement, false statement), where:
- condition= SUBSTRING(version(),1,1)=5
- true statement=SLEEP(10)
- false statement=NULL
- SUBSTRING (text, start, length) returns a substring starting from the position "start" of text and of length "length".
- In this case the conditional loop SUBSTRING(version(),1,1)=5 is TRUE because the database version starts by 5, actually 5.5.27, and as a consequence the SLEEP(10) true statement is successfully performed.