XSS跨站攻防安全

1.XSS简介

跨站脚本(cross site script)为了避免与样式css混淆,所以简称为XSS。 
XSS是一种经常出现在web应用中的计算机安全漏洞,也是web中最主流的攻击方式。那么什么是XSS呢? 
XSS是指恶意攻击者利用网站没有对用户提交数据进行转义处理或者过滤不足的缺点,进而添加一些代码,嵌入到web页 面中去。使别的用户访问都会执行相应的嵌入代码。 
从而盗取用户资料、利用用户身份进行某种动作或者对访问者进行病毒侵害的一种攻击方式。 XSS攻击的危害包括: 
1、盗取各类用户帐号,如机器登录帐号、用户网银帐号、各类管理员帐号 
2、控制企业数据,包括读取、篡改、添加、删除企业敏感数据的能力 
3、盗窃企业重要的具有商业价值的资料 
4、非法转账 
5、强制发送电子邮件 
6、网站挂马 
7、控制受害者机器向其它网站发起攻击
XSS主要原因: 
过于信任客户端提交的数据! 
XSS主要分类: 

反射型xss攻击(Reflected XSS) 又称为非持久性跨站点脚本攻击,它是最常见的类型的XSS。漏洞产生的原因
是攻击者注入的数据反映在响应中。一个典型的非持久性XSS包含一个带XSS攻击向量的链接(即每次攻击需要用
户的点击)。 

存储型XSS(Stored XSS) 又称为持久型跨站点脚本,它一般发生在XSS攻击向量(一般指XSS攻击代码)存储在网
站数据库,当一个页面被用户打开的时候执行。每当用户打开浏览器,脚本执行。持久的XSS相比非持久性XSS
攻击危害性更大, 因为每当用户打开页面,查看内容时脚本将自动执行。

2.构造XSS脚本

常用HTML标签

   
#会显示出一个长宽都是300的百度页面,你可以设置为其它页面的url


页面重定向 
  #跳转到百度界面


弹框警告并重定向 
 
 
这里结合了一些社工的思路,例如,通过网站内部私信的方式将其发给其他用户。如果其他用户点击并且相信了
这个信息,则可能在另外的站点重新登录账户(克隆网站收集账户)

访问恶意代码 
 
 #结合BeEF收集用户的cookie 

巧用图片标签 
 
 
 

绕开过滤的脚本 
大小写  
字符编码 采用URL、Base64等编码 
yjssjm 

收集用户cookie 
打开新窗口并且采用本地cookie访问目标网页,打开新窗口并且采用本地cookie访问目标网页。 
 
 
 
 


上面这些代码下面会有实验来一一解释,反射型xss和存储型xss都能用。

3.反射型XSS

简单来说反射型就是临时的xss,只有别人把该链接发给你,你点开之后才会中圈套。但是你不点开,正常的去访问该网站是没什么问题的。
这里我们用kali当做被下套的客户端,将我们做好的xss的链接地址复制到kali里面自带的浏览器上

弹框警告: 

XSS跨站攻防安全_第1张图片
XSS跨站攻防安全_第2张图片
XSS跨站攻防安全_第3张图片
XSS跨站攻防安全_第4张图片
所以,反射型xss只要我们不打开别人发的链接,自己去访问该页面是没有什么问题的。

页面重定向 
  #跳转到百度界面

直接跳转到百度界面
XSS跨站攻防安全_第5张图片

页面嵌套 

XSS跨站攻防安全_第6张图片

4.存储型XSS

存储型XSS(持久型XSS)即攻击者将带有XSS攻击的链接放在网页的某个页面,例如评论框等; 用户访问此XSS链接并执行,由于存储型XSS能够攻击所有访问此页面的用户,所以危害非常大。
简单来说,就是知道你访问这个网站中带有xss的区域就会中套。

弹框告警: 
text1

XSS跨站攻防安全_第7张图片
XSS跨站攻防安全_第8张图片
然后我们去kali上面打开
XSS跨站攻防安全_第9张图片
XSS跨站攻防安全_第10张图片
这几乎是存储型xss,在某个区域,只要你点开就会中了别人下的圈套。

5.自动化xss

我们这里用到kali里面自带的BeEF(牛)软件,用来实现自动化xss

启动Apache和BeEF: 
root@kali:~# service apache2 start

然后打开BeEF
XSS跨站攻防安全_第11张图片
XSS跨站攻防安全_第12张图片
XSS跨站攻防安全_第13张图片

 
注:192.168.13.145为BeEF所在机器,即Kali Linux IP

XSS跨站攻防安全_第14张图片
你会发现我们的代码没法完全复制进去,是因为网页给我们限制了字数,我们需要去修改一下
XSS跨站攻防安全_第15张图片
然后我们去kali里面登录BeEF:
username: beef
password: beef
XSS跨站攻防安全_第16张图片
XSS跨站攻防安全_第17张图片
XSS跨站攻防安全_第18张图片

命令颜色(Color): 
绿色 对目标主机生效并且不可见(不会被发现) 
橙色 对目标主机生效但可能可见(可能被发现) 
灰色 对目标主机未必生效(可验证下) 
红色 对目标主机不生效

XSS跨站攻防安全_第19张图片
这里面我们就可以对目标靶机进行各种操作,不用写代码,内部已经设置好了代码,我们只需要点点点,特别方便。

你们的评论和点赞是我写文章的最大动力,蟹蟹。

你可能感兴趣的:(XSS跨站攻防安全)