博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
xss实例-输出在<script></script>之间的情况
阅读量:7098 次
发布时间:2019-06-28

本文共 980 字,大约阅读时间需要 3 分钟。

1. 我们找到这么一个点,也是输入和输出都未过滤的一个点。相比教程第一例,其特殊之处在于,是输出在了 <script>[输出]</script>之间。

http://activity.soso.com/common/setParentsInfo.php?callback=aaaaaaaaa 如下图:callback参数未做过滤。 在【查看源代码】下,我们可以看到。

缺陷网页源代码:

 2. 碰到这种情况,我们一般有以下解法。 2.1 首先判断,是否过滤了 < , > , / 等符号, 2.2 如果都没有过滤,恭喜你,一般可以直接XSS了。代码如下: http://activity.soso.com/common/setParentsInfo.php?callback=aaaaaaaaa 原理入下图:

构造callback参数后的源代码
(_ret);}catch(err){aaaaaaaaa(_ret);}

2.3 如果过滤了 <, >,那么就无法使用上面的办法了。我们接着看 3

3. script代码里的构造。
友情提示:这里可能需要一点点 javascript 的知识才行哦~~
我们可以如下构造:

http://activity.soso.com/common/setParentsInfo.php?callback=eval('alert(1)');void

可以看到,源代码是下面的样子。

也就是说,我们插入的内容,使得这一段javascript依然【语法正确】,能够【正确执行】,并且能够执行【我们所插入的JS代码】,这样我们的目的就达到了。

构造后的源代码如下:

4. 这种输出在JS代码里的情况十分常见,但是呢?不幸的是,像这样没过滤的情况,却不是很常见。例如:
var a="[输出]"; // 通常程序员会把 " 过滤掉, 这样的话,一般来说,我们就很难构造。
但是,这并不是说,就一定是不能利用,后面我们会拿腾讯一些【比较有意思】的例子,来进一步说到 这个【输出在js里】的情况的~ 

 

修复方案:

这类XSS的模型通常是:

<script>...[输出]...</script>
<style>...[输出]...</script>
解决方案:
1. 过滤 </xxx> 组合
2. 针对输出在不同的场景,进行合适的过滤。

转载地址:http://euhql.baihongyu.com/

你可能感兴趣的文章
JMeter聚合报告(Aggregate Report)理解
查看>>
C# 多线程Thread.IsBackground=True的作用
查看>>
Oracle数据库安装问题记录
查看>>
Error:flask_sqlalchemy
查看>>
算法3-排序-简单选择排序
查看>>
poj 1743 Musical Theme (后缀数组)
查看>>
XACML学习
查看>>
Java中文乱码问题研究(二)
查看>>
easyui图标大全
查看>>
Emmet:HTML/CSS代码快速编写神器
查看>>
webpack实战
查看>>
虚幻4游戏开发_3_创建与继承材质
查看>>
win2003域控主备(热备)搭建
查看>>
浪潮之巅读后感
查看>>
Mathematica 函数调用发生异常时停止计算
查看>>
Clenshaw–Curtis quadrature
查看>>
ajax做分页
查看>>
CHIL-SQL-约束 (Constraints)
查看>>
64位操作系统在DOSBox中进入debug的问题
查看>>
ArrayList源码分析
查看>>