title: 《XSS-Labs》01. Level 1~10
date: 2023-10-02 21:58:27
updated: 2023-10-19 10:15:46
categories: WriteUp:Security-Lab
excerpt: 简单的验证方式、标签闭合构造 payload、onfocus 事件利用,js 伪协议、 标签 href 属性利用、大小写绕过、双写绕过、href 自动 Unicode 解码利用、onfocus 利用,js 伪协议,表单属性。
comments: false
tags:
top_image: /images/backimg/SunsetClimbing.png
靶场部署在 VMware - Win7。
只要手动注入恶意 JavaScript 脚本成功,就可以证明 xss 漏洞存在。
最简单的验证方法:
。
标签 href 属性利用。查看网站源码,可以发现 GET 传递的 name 参数值插入了 html 里。
直接测试 payload:
url + ?name=
先使用 测试一下,未成功。
【ctrl】+【u】查看一下源码。可以看到第一个输出结果被 html 实体转义了,但 value 中的没有。
那就闭合标签来构造 payload:
"> <"
使用 测试。查看源码可以看到符号都被转义了。
那这里就利用 onfocus 事件绕过。利用这个事件来绕过 < 和 > 号的过滤来执行 js。
payload:
' onfocus=javascript:alert() '
再次点击输入框就能执行脚本。
JavaScript 中的事件是与 HTML 元素相关联的动作或发生的情况,可以通过 JavaScript 代码来捕获和处理。
事件可以是用户交互,例如鼠标点击、键盘按键,也可以是浏览器或文档的状态变化,例如文档加载完成或元素的属性改变。
事件处理允许程序员编写响应用户操作或应用程序状态变化的代码。
onfocus 事件
、
和
标签一起使用。
标签有输入框,当输入框被点击的时候,就会触发 myFunction() 函数。原理与 Level-3 一样,只是要闭合的引号从单引号变成了双引号。
payload:
" onfocus=javascript:alert() "
测试 " onfocus=javascript:alert() "
,查看源码,过滤了 onfocus,且大小写绕过不管用。
利用 标签 href 属性。前提是【>】【<】【"】没失效。
payload:
"> xss <"
点击链接即可。
输入关键字测试一下:
onfocus <"
" oNfocus=jAvascript:alert() "
"> xss <"
传递下列关键字测试并查看源码。
oNfocus
看看源码。url + ?keyword=
都被转义了,但下面有几个隐藏的表单?
尝试用每个 name GET 传参。然后查看源码。
url + ?t_link=l&t_history=h&t_sort=s
可以看到有回显。那就利用这个表单构造 payload。
payload:
url + ?t_sort=" onfocus=javascript:alert() type="text
燕语如伤旧国春,宫花一落已成尘。
——《隋宫燕》(唐)李益