WackoPicko/Stored-SQL-Injection
Jump to navigation
Jump to search
You are here: | Stored SQL Injection
|
Description
When users create an account, they are asked to supply their first name. This supplied value is then used unsanitized on a page that shows other users who have a similar first name. An attacker can exploit this vulnerability by creating a user with the name "';DROP TABLE users;#" then visiting the similar users page.
Proof of Concept
data:image/s3,"s3://crabby-images/14f15/14f157780bad2668763b7de75acd994771e0a79b" alt=""
Note
Notice that you are unlikely to be able to realize this attack unless you use an old version of MySQL. Indeed, MySQL has now a protection mechanism that prevents from concatenating requests with a semi-column.
How to detect?
- See these tools.
- Refer to this article for more information on SQL injections.
How to protect against it?
Code
As we can see in the similar_login() function of the include/users.php script, the first request (tagged with the comment VULNERABLE REQUEST) is not properly sanitized):
function similar_login($login, $vuln = False) { if ($vuln) { /*** VULNERABLE REQUEST ***/ $query = "SELECT * from `users` where `firstname` like '%{$login}%' and firstname != '{$login}'"; } else { /*** SANITIZED REQUEST ***/ $query = sprintf("SELECT * from `users` where `firstname` like '%%%s%%' and firstname != '%s'", mysql_real_escape_string($login), mysql_real_escape_string($login)); } $res = mysql_query($query); if ($res) { while ($row = mysql_fetch_assoc($res)) { $to_ret[] = $row; } return $to_ret; } else { if ($vuln) { die(mysql_error()); } return False; } }