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

XSS 跨站脚本攻击总结

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

漏洞起因

可以输入的地方没有做好对应的过滤,引发的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 垂直居中的几种实现方式(css怎么实现垂直居中)

前言设计是带有主观色彩的,同样网页设计中的css一样让人摸不头脑。网上列举的实现方式一大把,或许在这里你都看到过,但既然来到这里我希望这篇能让你看有所收获,毕竟这也是前端面试的基础。实现方式备注:...

CSS 中各种居中你真的玩明白了么(css中的居中属性)

页面布局中最常见的需求就是元素或者文字居中了,但是根据场景的不同,居中也有简单到复杂各种不同的实现方式,本篇就带大家一起了解下,各种场景下,该如何使用CSS实现居中前言页面布局中最常见的需求就是元...

浅谈3种css技巧——两端对齐(css两侧对齐)

在出里文字比较多的网页,文字对齐其中采用的两端对齐,两端对齐的方法有三种方法,如下:1.使用text-align:justifytext-align:justify属性是全兼容的,使用它实现两端对...

从零开发HarmonyOS(鸿蒙)运动手表小游戏—数字华容道

本个demo将从零基础开始完成鸿蒙小游戏APP在可穿戴设备上的编译,此处以运动手表为例,在项目中我们所使用到的软件为DevEcoStudio,下载地址为:DevEcoStudio下载、DevEco...

教师如何制作随机点名系统,活跃课堂气氛

上课点名抽学生回答问题,做游戏……由老师口头点名,点谁回答总有点老师本人的情绪,且显得毫无趣味,但做一个点名系统,就不一样了,电脑随机抽出的名字,不仅公平,还会给孩子们带来一种不一样的感受。那么怎么做...

看京铁人如何破解电煤运输&quot;烤&quot;验

“天气太热了!空调是我的避暑必备神器再往冰箱里冻些雪糕和西瓜电风扇也要24小时上岗了”近日京津冀地区迎来高温天气小伙伴们都在分享解暑妙招但这些妙招背后都离不开一个字——“电”为确保电力平稳“迎峰度夏”...

回家的路就是最美的风景 幸福就在前方

2025年春运启动以来,无数在外游子踏上归乡旅程。为了帮助更多旅客按时回家过年,还有很多人不分昼夜、不辞辛苦地奔波在铁路线上。“我的列车飞驰而过,那是梦想的前方,回家的路就是最美的风景。”END&l...

如何做出一个香消玉殒的网页文字特效

最近,迷上了CSS3特效,空闲时间学一些小案例,非专业,爱好。不断学习也能掌握一些更为全面的html,css,JavaScript的知识,以小博大,从兴趣出发再掌握更多网页开发知识。闲言少叙,直接开怼...

第1000篇原创,我想对你说______(2021我想对你说1000)

亲爱的小伙伴今天您看到的这篇推送是“北京铁路”发布的第1000篇原创作品!这不仅是一个数字的跨越更是我们一路走来与每一位关注者共同铸就的辉煌里程碑每一篇文章都承载着我们的心血与热情每一次传播都离不开大...

动车组的“家”在哪里?(动车组的"家"在哪里?举例说明)

夜幕降临随着动车组列车驶入站台乘客陆续离开动车组也完成了一天的工作准备启程回“家”有小伙伴儿会问“为什么大多数动车组列车夜间不运行呢?”这是因为白天行驶一天的动车组要利用晚上的时间进行全面检查、维修和...

这套铁路“高考”卷,请你来作答(郑州铁路职业技术学院高考河南录取分数线)

今天是2025年全国高考的第一天小编为大家准备了一套北京铁路版的试卷满分120分共12道单选题快来试试你能得多少分吧!·<animateattributeName="opacity"begi...

HarmonyOS Text组件Span间距解决方案

HarmonyOSText组件Span间距解决方案一、问题分析在HarmonyOS开发中,Text组件内的Span子组件无法直接设置margin/padding属性,需要通过文本级属性实现间距控制。...

考“火车驾驶证”,难不难?(火车驾驶证怎么考需要什么条件)

····<animateattributeName="height"begin="0.1"dur="0.01s"fill="freeze"to="0"/>00:0002:59未加...

高温?京铁人:我有“物理外挂”!(点开看有多爽)

近几日华北地区气温不断上升高温来袭坚守岗位的京铁人开启清凉避暑的“物理外挂”快动动手指点开看看吧·<animateattributeName="opacity"begin="click+0....

2025年Top30 CSS面试题及答案(css常考面试题)

概述CSS(层叠样式表)是构建美观、响应式网站的关键技术。无论您是在准备前端开发者面试还是复习知识,这里都有一份精心挑选的2025年每个开发者都应该知道的30个CSS面试题及答案。1.什么是CSS...