目录
🎯 XSS-Labs 前 10 关 通关命令 & 注入方式总结
🎯 XSS-Labs 前 10 关 通关命令 & 注入方式总结
| 关卡 | 核心过滤/特点 | 注入 payload(命令) | 注入方式与原理 |
|---|---|---|---|
| Level 1 | 无任何过滤,直接输出到页面 |
| 直接在 URL 的 |
| Level 2 | 输入在 HTML 标签属性内,需闭合标签 |
| 用 |
| Level 3 | 尖括号 |
| 用单引号闭合属性,添加 |
| Level 4 | 尖括号被过滤,但可用事件属性 |
| 双引号闭合属性,插入 |
| Level 5 |
|
| 用 a 标签的 |
| Level 6 | 大小写混合可绕过过滤 |
| 用大小写混淆绕过关键词过滤 |
| Level 7 | 重复关键词会被删掉一次,可用嵌套绕过 |
| 利用重复替换漏洞,构造出合法 script 标签 |
| Level 8 | 过滤了大部分关键字,但支持 HTML 实体编码 |
| 将 |
| Level 9 | 必须包含 |
| 用 HTML 实体编码 |
| Level 10 | 隐藏输入框 |
| 闭合 value,修改 type 为 text,加入 |
上述表格是根据下面内容进行总结,命令复制有可能有遗漏的标点符号等,若上述表格命令有错请查看下面详细笔记,下面笔记保证正确
一、leve1
进入第一关

把地址栏的test换成<script>alert(1)</script>

点击回车成功过关

二、leve2
进入第二关

发现只有个搜索框,输入<script>alert(1)</script>试试

发现这种方法不行,鼠标右键点击查看源代码

发现提交的值被储存到了value值中,修改闭合方式来闭合 value 值,插入 js 代码便能执行

输入"> <script>alert(1)</script>

点击搜索便可通关

三、leve3
进入第三关
输入<script>alert(1)</script>查看页面源代码


发现输入的数据还是在value值中,但是两个尖括号< >被过滤了,所以输入的时候无法使用尖括号,并且value是单引号,所以要用单引号闭合
直接输入'> οnclick='alert(1)

点击搜索,再点击一次输入栏才显示成功

我还测试了一下,如果输入'> οnfοcus=javascript:alert('xss') '或者输入' οnfοcus=javascript:alert('xss') '都可以成功,但是弹窗会一直反复的出现,你需要点好几次确定才能跳转到第四关

四、leve4
进入第四关
直接输入<script>alert(1)</script>查看源代码

发现<>还是被过滤了,但是value使用的是双引号
直接把上一题的代码的单引号换为双引号直接放进去" onclick = alert(1) "或者" οnfοcus=javascript:alert(1) "
但是第二个输入进去的时候还是会一直弹窗

五、leve5
进入第5关
输入查看源代码


发现尖括号可以输入<>但是script关键字被添了下划线,那就不使用这个关键字,换一个关键字,使用" οnfοcus=javascript:alert(1) "试试

发现还是被添加了下划线。使用" onclick = alert(1) "也不行

使用a标签的伪协议"> <a href="javascript:alert ('xss')">

成功了
六、leve6
进入第6关
查看页面源代码


和上一关类似,这次除了 <script> 标签,<a>标签的 href 值也会插入一个下划线,而且<img> 标签的 src 属性和 onerror 属性也会被插入下划线
所以使用大小写转换绕过"> <sCript>alert(1)</sCript>

七、leve7
进入第7关
输入<script>alert(1)</script>之后发现script被过滤了

那双写script,"> <scscriptript>alert(1)</scscriptript>

八、leve8
进入第8关
查看页面源码发现,大小写替换会被检测,script,javascript也会被添加下划线,从而选择使用HTML实体编码的格式
javascript:alert(1)

或者使用16进制编码也可以
javascript:alert(1)

九、leve9
进入第9关,输入<script>alert(1)</script>显示链接不合法

这种情况加入http://就欧克了,但是肯定不能加在前面,加前面这语句就被注释了所以只能加后面
<script>alert(1)</script>//http:// 发现script被过滤了

因为javascript也被过滤了,所以使用s来代替s,所以使用javascript:alert(1)//http://

十、leve10
打开第10关,你会发现页面上只有一个搜索框,输入东西会显示搜索结果。
但是你试着输入 <script>alert(1)</script>没反应,因为后台把 <和 >都转义了(变成 <>),所以标签不会被执行。
那怎么办?我们得找别的办法。
-
在网页地址栏里,你会看到 URL 后面有
?keyword=xxx,这是传参数的地方。 -
我们点开网页的【查看源代码】(右键 → 查看网页源代码),会发现除了 keyword,还有几个隐藏的输入框:
-

查看源码可见三个隐藏的表单字段:t_link、t_history、t_sort。向三者逐一传参测试,发现只有 t_sort 的值会被回显到页面中
把网址?后面的内容替换为t_sort=" οnfοcus=alert(1) autofocus type=text
onfocus是一个事件属性当这个输入框获得焦点的时候,就执行后面的代码。
autofocus页面加载完成后,自动让这个输入框获得焦点。结合onfocus,就能做到页面一打开就自动弹窗。原本输入框是
type="hidden"(看不见)。这里我们改成
type="text",让它变成一个普通可见的文本框,这样才能真正获得焦点、触发事件。

回车然后就成功了

但是显示成功的弹窗要点好一会才可以跳到下一关,不知道是不是bug
:XSS-Labs 前 10 关 通关命令and实战笔记&spm=1001.2101.3001.5002&articleId=155559813&d=1&t=3&u=dd006cffefa6425599aba94ee5754452)
8271

被折叠的 条评论
为什么被折叠?



