百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

XSS 跨站脚本攻击总结

zhezhongyun 2025-02-09 15:01 17 浏览

漏洞起因

可以输入的地方没有做好对应的过滤,引发的xss攻击

漏洞危害

  1. 盗取cookie
  2. 劫持用户浏览器
  3. 钓鱼攻击
  4. 挂马
  5. 在一定的条件下可以getshell
  6. 会话劫持

漏洞类型

  1. 反射型XSS(危险级别:低),插入的语句停留在当前页面。
  2. DOM型XSS (危险级别:中), DOM型xss又分为两种 (a.可见型、b.不可见型),插入的语句影响js 。
  3. 存储型XSS(危险级别:高),插入的语句保存在数据库 。
  4. 其他型XSS(例如:Flash xss)。

漏洞实验

本次实验我们以著名的安全脆弱性平台DVWA为例:

在low级别下的测试,没有任何防御。可以插入任意标签如:




如果过滤了alert()如何绕过呢?

直接上后端PHP代码:

前端显示html代码如下:




    
    Demo1


输入你的名称

输入: 提交

当输入alert的时候就会被替换成空,当然我们可以使用其他的什么标签来代替script,但是如果只用script如何绕过呢?使用js转义。将alert转义。

当js解释器在标识符名称(例如函数名,属性名等等)中遇到unicode编码会进行解码,并使其标志符照常生效。而在字符串中遇到unicode编码时会进行解码只会被当作字符串。

也就是说unicode编码只能编码属性名

示例payload如下:

经过js转义后,代码如下:

注意:使用unicode编码之前要确定对方有没有过滤“\”

html转义:

当浏览器接受到一份HTML代码后,会对标签之间(

xxx

等,之间的情况:

var w=[$q]$q;";
echo $c;
#echo " ";
/*
 
 *
 */
#echo "";
?>

绕过:

]";
/*
 
 *
 */
#echo "";
?>

绕过:

1' onclick='alert(1)

假设输出在img标签里:

";
echo $c;
#echo "";
#echo " ";
/*
 
 *
 */
#echo "";
?>

绕过:

'1/**/onerror='alert(1)

输出在标签里的绕过总结:

  1. 先想办法闭合周围的什么双引号之类的东西
  2. 判断有什么过滤掉的,如果没有过滤自然最好
  3. 查询标签对应可以执行js的属性,然后插入代码即可

DOM型xss分为两种:

  1. 可见型DOM xss
  2. 不可见型DOM xss

何为DOM?,你插入的代码会暂存在某些标签之中,并且影响输出。

DVWA的DOM xss就是不可见类型。

源代码不可见:

但是F12可见:

low级无任何防御直接插入payload:

medimu级过滤了script:

使用: //要闭合select标签,因为img在select标签里面是不可见的

high级对default进行了判断:

使用#杀掉判断:

#

存储型xss:当我们插入的恶意代码都会保留在数据库,下次在访问此页面的时候就会自动执行js。

温馨提示:用beef来配置存储型xss是个不错的选择哦!

总结:

xss漏洞起因
    没有做好对应的过滤标签措施,导致攻击者可以注入恶意代码

对付那种无任何过滤的
    
    
    
    GO

输出在之间的情况(意思就是你在script里面,得把前面的闭合了在注入语句,然后因为你在script里面直接输入语句即可)
    先闭合上一个script然后在注入恶意代码:

    构造的xss语句:http://xxx.com/jj.php?xxx=%0aalert(1) //) #通过%0a换行符,换到了没有注释的下一行然后闭合掉后面的括号

使用反斜杆构造xss
    当输入的语句处于多行js代码之中,使用\分开,例子:
    
    使用\分割语句然后想办法闭合

 :反弹xss一般出现在url拦

DOM型xss
DOM型的xss就是通过输入,改变了js代码的一部分。dom型xss又分两种:
1.可见型DOM xss,输入的东西改变了页面的源码。但是F12查看源码可见
类似于:
按职业1检索:aaaaaaa 
aaaaa为我们输入的,假设现在<,>被过滤了。但是\没被过滤,该如何构造xss呢 由于\没有被过滤,使用unicode编码<和>,变为 被url解释器解释完后为,url中出现了javascript:,指明了后面的语句要当作js执行,所以再次把解释后的字符交给js解释器解释,可以弹窗。 当js解释器在标识符名称(例如函数名,属性名等等)中遇到unicode编码会进行解码,并使其标志符照常生效。而在字符串中遇到unicode编码时会进行解码只会被当作字符串。如: unicode编码在标签的属性之中可用,如果在输出使用不会影响上下文 参考文章:https://www.cnblogs.com/iceli/p/8598709.html 2.不可见型DOM xss 类似于DVWA里的DOM型xss,只能用调试工具定位。审核源代码是看不见的 记录一些DOM型xss常用的语句: 在iframe中执行js: IE执行VBScript代码 上面的变体 chrome下的srcdoc属性 总结:在探测一个地方是否有xss的时候,插入好搜索的语句例如:aaaaaa。然后f12源码搜索,分析出现的地方,看看哪里能实现xss。如果有被过滤 了,先试试html转义,注意闭合。当\符号没被过滤的时候可以使用unicode编码来进行代替被过滤的函数或符号 (前提是在script标签里) 存储型xss: 一定要记住本节最开头的话,存储型XSS,输出的位置不一定出现在输入的位置。 7. 因而我们有时候需要逆向的思维,来寻找存储型XSS。大概思路如下: 7.1 先找到输出点,然后猜测此处输出是否会被过滤。 7.2 如果觉得可能没过滤,我们再找到这个输出是在哪里输入的。 7.3 接着开始测试输入,看输出的效果。 7.4 如果没过滤,那么你就成功了,否则你可以放弃掉它。 xss 存储型payload:http://html5sec.org/

相关推荐

关于CSS伪类&amp;伪元素的一些知识——CSS学习之路

最近两天接触到了CSS伪类和伪元素之间的关系,伪类和伪元素在css代码中使用:做标识符,同来识别元素。我倒是理解,可是为什么时常见到一会用一个冒号,一会用两个,然后就感觉很迷糊了,于是就有了这一篇文章...

CSS中before 和after的用法

CSS有两个说不上常用的伪类:before和:after,偶尔会被人用来添加些自定义格式什么的,但是它们的功用不仅于此。一基本语法在了解进阶的应用之前,先来了解一下语法规则。平常仅仅需要将这...

CSS 样式总翻车?5 个实战技巧让布局效率暴增 200%!

前端工程师们,是不是经常遇到这种崩溃瞬间?精心设计的CSS样式,一到不同浏览器就“变形走样”,或是响应式布局怎么调都达不到预期效果,改来改去不仅浪费时间,还容易产生一堆冗余代码。别慌!今天带来...

微信小程序入门教程之二:页面样式

这个系列的上一篇教程,教大家写了一个最简单的Helloworld微信小程序。但是,那只是一个裸页面,并不好看。今天接着往下讲,如何为这个页面添加样式,使它看上去更美观,教大家写出实际可以使用的页...

网格不迷路:用 CSS 网格生成器打造完美布局

前言你是否曾因写错grid-template-areas而捶键盘?是否在面对千层嵌套的复杂布局时,瞬间怀疑人生,甚至思考要不要转行去卖奶茶?别慌,CSS网格生成器闪亮登场,像拼乐高一样,帮你轻松...

MFC转QT:Qt高级特性 - 样式表

Qt样式表概述Qt样式表(QtStyleSheets)是基于CSS的样式系统,允许开发者以类似于Web前端的方式定制Qt应用程序的外观。这一特性极大地简化了Qt应用的界面定制,提供了比MFC更强大...

什么是CSS?

CSS是一种用来描述网页样式的语言,它可以控制HTML元素的颜色、大小、位置、布局等外观效果。CSS的全称是层叠样式表(CascadingStyleSheets),它的基本语法由选择器和...

从零开始学习网站CSS布局

CSS是前端开发中的重要技术之一,而CSS布局则是CSS技术中最基础的一部分。学习CSS布局是Web开发者的必修课,也是掌握CSS技能的基石。CSS布局指的是如何使用CSS定位和排版HTML元素。CS...

CSS3 渐变类型及其语法

线性渐变:CSS3可以让背景产生渐变效果,渐变属性有两种,即linear-gradient(线性渐变)和radial-gradient(圆形渐变),语法如下background:linear-gra...

五大顶级CSS性能优化工具,值得程序员一试!

为什么Web页面的加载速度如此重要?在这个信息化的时代,如果一个网站的加载时间过长,大部分用户会极其不耐烦地选择“关掉”!这让辛辛苦苦熬夜敲代码的程序员们情何以堪,不管网站功能如何强大,用户根本都没来...

get css中的clamp()函数,好用到起飞

CSS中有大量令人惊叹的属性和特性,但似乎没有人谈论的是clamp函数。这个函数让我们可以对任何CSS属性执行min-width,max-width,和之类的操作。CSSclamp语法cl...

Google Chrome终于支持CSS Variables了

这篇文章要报道的并不是“新闻”,因为W3C早已开始着手CSS变量(又称‘自定义属性’)方面的工作。而作为CSS4非正式标准的一部分,Mozilla早在Firefox版本号还是29的时候就已经支持它了。...

CSS3 过渡与动画

在现代网页设计中,平滑的过渡和生动的动画效果已成为提升用户体验不可或缺的元素。CSS3为我们提供了强大的transition和animation属性,让开发者能够轻松实现各种视觉效果。本文将...

css基础篇11--表格样式

目标表格边框合并表格边框的间距设置表格标题位置的设置表格可以说是网页必备的元素之一,但是原生的表格样式都是很丑,列如表格加入边框的默认情况下,单元格与单元格之间有一定的空隙;设置单元格边框间距等等,都...

WebDriver-工具辅助生成XPath语法和CSS语法

1.FireBug插件1.1生成XPath语法打开Firefox浏览器FireBug插件,单击插件左上角的鼠标箭头,再单击页面上需要定位的元素,在元素行上右击弹出快捷菜单,选择“复制XPath”,将会...