当前位置:网站首页>xss的绕过
xss的绕过
2022-07-31 00:00:00 【Miracle_ze】
本次绕过在网站xss.haozi.me进行的绕过 练习网站
输出弹出就成功
0x00:闭合标签

本题很简单只需要闭合标签,并输入弹窗标签
</div><script>alert(1)</script><div>

0x01:闭合标签,textarea内元素为文本元素

本题很简单只需要闭合标签,并输入弹窗标签。不能在textarea标签直接写。因为编码无法识别因为会使他识别为文本
</textarea><script>alert(1)</script><texarea>

0x02:闭合引号

题目我们输入的内容在value里面,为此我们要跳出来,再输入弹窗语句。因此我们要先闭合双引号再写弹窗语句。
aa" ><script>alert(1)</script>

0x03:实体编码

题目将[、]、(、)过滤了,即在输入了这其中的一个符号的时候不显示
因此使用实体编码,不过不能像之前那个用script标签来弹窗,因为script不支持编码。但是可以把括号换为`【反引号】就可以使用script标签
综上可以使用img与svg标签
html支持实体编码,Unicode不行是因为js中不能编码符号
<svg/οnlοad="alert(1)">
<img src=1 onerror="alert(1)">
<script>alert`1`</script>



上输入的alert`1`反引号涉及到模板字符串。
详情解释请看:[模板字符串](https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Template_literals)
0x04:实体编码

0x04与0x03异曲同工,只是0x04多禁用了符号。除了不能使用alert的`【反引号】形式其他与0x03一样。
<svg/οnlοad="alert(1)">
<img src=1 onerror="alert(1)">


0x05:注释方法

题目将–>替换为’’,其目的是防止你闭合注释。但是闭合这个注释不只–>。还可以–!>
html注释:
1、<!-- -->
2、<!-- -->
JavaScript的注释
1、//
2、 开头使用 -->
解题:
--!><script>alert(1)</script>

0x06

题目将“”on开头接=“”的字符过滤了,即把事假一定程度上禁用了。但是这有个小技巧就是html换行的=开头接上一个字符。考虑到输入的input标签没有设置类型,并且我们输入内容在标签内。因此image与
type="image" src=1 onerror
=alert(1)

0x07:不严谨性的自动补全

条件上
<\/?[^>]表示只要匹配到<0次到1次与匹配到>就过滤他们包的所有内容。
即< 内容>这整块过滤掉。所有我们需要写不用>来闭合的标签。因为html的不严谨性,对单标签没有写>会自动补全。所以使用img标签是一种解法
<img src=1 οnerrοr="alert(1)"

0x08:换行


上图表示当你要输入闭合style时进行过滤替换,为此我们可以理由html的不严谨性进行换行处理。
</style >
<script>alert(1)</script>

0x09:@的分割作用

题目显示我们必须包含http://www.segmentfault.com,但是又要显示弹窗。那么这就涉及到了一个知识点。
@的分割作用,前面表username password 后面是地址和端口。
即username password @ 地址 port
http://[email protected]/test1.js
test1.js是保存在本地的文件

0x0a:@的分割作用与转码

这个同0x09一样,虽然他转码了。单子url将其自动转码回来了
http://[email protected]/test1.js

0x0b :大写用svg

在题目中使用了toUpperCase函数,使input输入的内容都大写。为此我们可以使用svg,当然每次这都会想到script但是它会使文本变成文本元素。
ſ 这个是一个可以把大写转小写s的
<svg/οnlοad=alert(1)>
<ſvg/οnlοad=alert(1)>


0x0c:大写svg

同上题一样,只是这里多了个添加把script过滤了。
<svg/οnlοad=alert(1)>
<ſvg/οnlοad=alert(1)>


0x0d:换行逃单行注释

上图我们在注释中输入,标签它过滤了/ 、’和"。这样不想我们闭合。
题目可见它是单行注释所有我们进行换行,再利用js的开头注释–>把一起换行的后半部分注释掉。
alert(1)
-->

0x0e:ſ 可以表示s

同0x0b一样使用ſ 符号来代表s。因为题目过滤了所有字母开头,并且使其全大写。只有svg大写与ſ 符号来解决。
<ſvg/οnlοad="alert (1)">

0x0f:Unicode编码转ascll,html识别转回

上图虽然它将符号都转码了,可html识别时会自动转回来。为此我们就只管着输入的地方。将其闭合,输入弹窗,把干扰弹窗的后面部分注释了
aa');alert(1)//

0x10:数据直接输入

这里没有要求,就是数据直接输入显示
alert(1)

0x11:JavaScript的函数认识度

我们输入地方在onsole.log()函数。console.log方法用于在控制台输出信息。它可以接受一个或多个参数,将它们连接起来输出。这里我们是无需它。只需要将其闭合,然后连接alert的弹窗,并把影响弹窗的后半内容注释掉
"),alert(1)//

0x12:转义符:\ 的应用

基本要求与0x11一样,不同的是"被替换为"
为此我们想闭合必须让其无效化,为此使用\转义字符使其失效。其余内容与0x11一样。
"),alert(1)//

边栏推荐
- 46.
- 如何在 AWS 中应用 DevOps 方法?
- Bugku sql注入
- In MySQL, the stored procedure cannot realize the problem of migrating and copying the data in the table
- WebServer process explanation (registration module)
- software development design process
- ZZULIOJ:1119: sequence order
- (WebFlux)001、如何自定义注解实现功能
- pytorch的安装注意事项
- H5跳转微信公众号解决方案
猜你喜欢

flex-direction容器属性

45.【list链表的应用】

Reverse linked list - in-place inversion method

Shell programming conditional statement test command Integer value, string comparison Logical test File test

递增三元组

Shell编程条件语句 test命令 整数值,字符串比较 逻辑测试 文件测试

@requestmapping注解的作用及用法

HCIP第十五天笔记

软件测试三阶段,你在哪一步?

Steven Giesel 最近发布了一个由5部分内容组成的系列,记录了他首次使用 Uno Platform 构建应用程序的经验。
随机推荐
leetcode:127. 单词接龙
MPI简谈
Dry goods | 4 tips for MySQL performance optimization
How to install joiplay emulator rtp
【萌新解题】删除链表的倒数第 N 个结点
uniapp develops WeChat applet - soft exam brushing applet
数据清洗-使用es的ingest
How to ensure the consistency of database and cache data?
宽客必备神器-AKShare
ZZULIOJ: 1120: the most value to exchange
乌克兰外交部:乌已完成恢复粮食安全出口的必要准备
360核心安全大脑3.0正式发布,构建政企用户的“能力中枢平台”
Calico 网络通信原理揭秘
transition过渡&&animation动画
What are the efficient open source artifacts of VSCode
【LeetCode】70. 爬楼梯 - Go 语言题解
怎么开通代付通道接口?
第一个独立完成的千万级项目
软考总结
一款好用的接口测试工具——Postman

