Requirement:
data:image/s3,"s3://crabby-images/2f932/2f932df213ad268e21ab63085a9a097574146712" alt=""
Solution:
As we can see from the above picture, the SQL statement is
SELECT * FROM user_data WHERE last_name = 'Your Name'
Where the 'Your Name' is from user's input and here is no any client input validation. So here is the SQL Injection point.
Attacking process:
Conduct the following malicious input to break the SQL logic
Input: Smith' or 'a' = 'a (take care with the end single quote)
Then the SQL statement will become:
SELECT * FROM user_data WHERE last_name = 'Smith' or 'a' = 'a'
This will make server to return all of data.
pic-1 is normal request:
data:image/s3,"s3://crabby-images/77738/777387ca9e32df40251144a1343d37acb4f6f37e" alt=""
pic-2 is malicious request:
data:image/s3,"s3://crabby-images/477de/477de0750ac05f6e60da55e78a9cf48cc12b6ff5" alt=""
Instead, we can use comment mark to ignore the end single quote.
Attacking Input: Smith' or 1=1 -- ("--" is comment mark, anything followed will be ignored)
Then the SQL statement will become:
SELECT * FROM user_data WHERE last_name = 'Smith' or 1=1 --'
This also get all of data.
data:image/s3,"s3://crabby-images/7739a/7739a7383a781b0e1f11fc77690323c4b6aa852b" alt=""
Reference:
[1] https://www.owasp.org/index.php/SQL_Injection
[2] https://www.owasp.org/index.php/Testing_for_SQL_Injection_%28OWASP-DV-005%29
[3] https://www.owasp.org/index.php/Reviewing_Code_for_SQL_Injection
[4] http://ferruh.mavituna.com/sql-injection-cheatsheet-oku/
data:image/s3,"s3://crabby-images/7936d/7936d56db2118f3959585218835b33fc1f1f4fc5" alt=""
Solution:
As we can see from the above picture, the SQL statement is
SELECT * FROM user_data WHERE last_name = 'Your Name'
Where the 'Your Name' is from user's input and here is no any client input validation. So here is the SQL Injection point.
Attacking process:
Conduct the following malicious input to break the SQL logic
Input: Smith' or 'a' = 'a (take care with the end single quote)
Then the SQL statement will become:
SELECT * FROM user_data WHERE last_name = 'Smith' or 'a' = 'a'
This will make server to return all of data.
pic-1 is normal request:
pic-2 is malicious request:
Instead, we can use comment mark to ignore the end single quote.
Attacking Input: Smith' or 1=1 -- ("--" is comment mark, anything followed will be ignored)
Then the SQL statement will become:
SELECT * FROM user_data WHERE last_name = 'Smith' or 1=1 --'
This also get all of data.
Reference:
[1] https://www.owasp.org/index.php/SQL_Injection
[2] https://www.owasp.org/index.php/Testing_for_SQL_Injection_%28OWASP-DV-005%29
[3] https://www.owasp.org/index.php/Reviewing_Code_for_SQL_Injection
[4] http://ferruh.mavituna.com/sql-injection-cheatsheet-oku/
data:image/s3,"s3://crabby-images/7936d/7936d56db2118f3959585218835b33fc1f1f4fc5" alt=""
raw
ReplyDelete