xss复现

server/2024/9/22 21:54:27/

目录

反射型 

Ma Spaghet!

Jefff

Ugandan Knuckles

onfocus

Ricardo Milos

Ah That's Hawt

location

Ligma

Mafia

构造函数

dom破坏

Ok, Boomer


反射型 

Ma Spaghet!

javascript"><!-- Challenge -->
<h2 id="spaghet"></h2>
<script>spaghet.innerHTML = (new URL(location).searchParams.get('somebody') || "Somebody") + " Toucha Ma Spaghet!"
</script>

分析代码:将get传参somebody直接放在h2标签中

 尝试传入script语句

没有触发

 这里使用的是innerHTML函数,查询得知该函数不会执行<script>标签

 但这里仅仅是不执行<script>标签,可以使用<img>

搞定

Jefff

javascript"><!-- Challenge -->
<h2 id="maname"></h2>
<script>let jeff = (new URL(location).searchParams.get('jeff') || "JEFFF")let ma = ""eval(`ma = "Ma name ${jeff}"`)setTimeout(_ => {maname.innerText = ma}, 1000)
</script>

 分析代码:get传参,与字符串拼接后放在h2标签

这里有双引号限制,可通过闭合双引号来逃逸双引号

成功

Ugandan Knuckles

javascript"><!-- Challenge -->
<div id="uganda"></div>
<script>let wey = (new URL(location).searchParams.get('wey') || "do you know da wey?");wey = wey.replace(/[<>]/g, '')uganda.innerHTML = `<input type="text" placeholder="${wey}" class="form-control">`
</script>

分析代码:get传参,放入<input>标签 ,但这里过滤了<和>

不过这里依然可以用闭合双引号的方式,增加一个点击事件

不过这种方式需要手动点击输入框才可以触发

onfocus

input标签自带一个焦点属性,按tab键可以切换焦点,当焦点在input标签时触发

不过这种方式依然需要手动触发,但input还要自动聚焦autofocus

自动触发

Ricardo Milos

javascript"><!-- Challenge -->
<form id="ricardo" method="GET"><input name="milos" type="text" class="form-control" placeholder="True" value="True">
</form>
<script>ricardo.action = (new URL(location).searchParams.get('ricardo') || '#')setTimeout(_ => {ricardo.submit()}, 2000)
</script>

 分析代码:get传参,默认为#,两秒后进行form表单提交

form表单的action是支持javascript:伪协议的

成功

Ah That's Hawt

javascript"><!-- Challenge -->
<h2 id="will"></h2>
<script>smith = (new URL(location).searchParams.get('markassbrownlee') || "Ah That's Hawt")smith = smith.replace(/[\(\`\)\\]/g, '')will.innerHTML = smith
</script>

 分析代码:get传参放入h2标签,不过过滤了括号,反引号和转义字符

尝试编码%来绕过

失败了

 因为alert是js中的函数,而js不能对符号编码,所以失败

location

这里使用location属性,经查询,location会将后面的值当作字符串

将alert转为字符串后,再编码符号

成功

Ligma

javascript">/* Challenge */
balls = (new URL(location).searchParams.get('balls') || "Ninja has Ligma")
balls = balls.replace(/[A-Za-z0-9]/g, '')
eval(balls)

这里过滤了字母和数字

使用编码的方式

成功

Mafia

javascript">/* Challenge */
mafia = (new URL(location).searchParams.get('mafia') || '1+1')
mafia = mafia.slice(0, 50)
mafia = mafia.replace(/[\`\'\"\+\-\!\\\[\]]/gi, '_')
mafia = mafia.replace(/alert/g, '_')
eval(mafia)

过滤了alert,不过prompt、confirm也能实现弹窗

构造函数

Function 构造函数创建一个新的 Function 对象。直接调用此构造函数可用动态创建函数

Function(/ALERT(1337)/.source.toLowerCase())()

将ALERT转小写后执行

dom破坏

Ok, Boomer

javascript"><!-- Challenge -->
<h2 id="boomer">Ok, Boomer.</h2>
<script>boomer.innerHTML = DOMPurify.sanitize(new URL(location).searchParams.get('boomer') || "Ok, Boomer")setTimeout(ok, 2000)
</script>

 分析代码:两秒后执行ok,不过奇怪的是这里并没有定义

Dom Clobbering 就是⼀种将 HTML 代码注⼊⻚⾯中以操纵 DOM 并最终更改⻚⾯上 JavaScript ⾏为的 技术。 

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><a id="test1" href="aaaaaaaa"></a>
</body>
<script>alert(test1)
</script>
</html>

可以发现herf中的值会当作字符串展示,而setTimeout能够执行字符串

payload=<a id="ok" href="javascript:alert(1)">

 没有绕过前端框架

使用了白名单

javascript换掉

 

成功


http://www.ppmy.cn/server/101382.html

相关文章

【鸿蒙学习】使用HarmonyOS NEXT与Uniapp开发同一鸿蒙应用的区别及分析

随着鸿蒙操作系统的普及&#xff0c;开发者面临着多种开发工具的选择。本文将通过开发、部署、运行、使用四个方面&#xff0c;详细分析使用HarmonyOS NEXT与Uniapp开发同一鸿蒙应用的区别&#xff0c;为开发者提供参考。 一、引言 鸿蒙操作系统&#xff08;HarmonyOS&#xf…

C# XML 加密解密

步骤 1: 生成RSA密钥 首先&#xff0c;我们需要生成一个RSA密钥对&#xff0c;用于加密和解密。 using System; using System.Security.Cryptography; using System.Xml;public class XmlEncryptionExample {public static RSAParameters publicKey;public static RSAParamet…

speech语音audio音频

在信号处理和语言技术领域&#xff0c;speech 和 audio 是两个相关但不同的概念。它们有各自的定义和应用场景。以下是对这两个术语的详细解释&#xff1a; 1. Speech&#xff08;语音&#xff09; Speech 主要指的是人类说话时产生的声音。它是人类语言交流的一种主要形式&a…

uniapp与设备通信 通过mqtt实现通信

MQTT (Message Queuing Telemetry Transport) 协议类型&#xff1a;MQTT 是一种轻量级的发布/订阅消息传输协议&#xff0c;通常基于 TCP/IP 实现。 功能&#xff1a;设计用于高延迟网络环境中&#xff0c;在带宽有限的情况下高效传输小量数据。广泛用于物联网&#xff08;Io…

Leetcode—1006. 笨阶乘【中等】

2024每日刷题&#xff08;156&#xff09; Leetcode—1006. 笨阶乘 实现代码 class Solution { public:int clumsy(int n) {stack<int> st;st.push(n);n--;int idx 0;while(n ! 0) {if(idx % 4 0) {int num st.top() * n;st.pop();st.push(num);} else if(idx % 4 …

C/C++中奇妙的类型转换

1.引言 大家在学习C语言的时候&#xff0c;有没有遇见过类似于下面这样的代码呢&#xff1f; // 整形转bool int count 10; while(count--) {cout << count << endl; }// 指针转bool int* ptr cur; while(ptr) {//…… } 众所周知&#xff0c;while循环的判断…

Redis相关介绍

Redis 是一个开源的高性能键值数据库&#xff0c;它不仅可以作为数据库使用&#xff0c;还可以作为缓存和消息中间件。Redis 支持多种数据结构&#xff0c;包括字符串、哈希、列表、集合、有序集合、位图、超日志和地理空间索引等。它因其高性能和丰富的数据结构支持在各种场景…

用Python实现9大回归算法详解——05. 梯度提升回归(Gradient Boosting Regression)

1. 梯度提升回归的基本概念 1.1 什么是梯度提升&#xff1f; 梯度提升是一种集成学习方法&#xff0c;通过组合多个弱学习器来构建一个强大的预测模型。在梯度提升框架中&#xff0c;每个弱学习器都试图修正前一个模型的错误。与简单的加法模型不同&#xff0c;梯度提升通过逐…