当前位置: 首页 > news >正文

xss复现

目录

反射型 

Ma Spaghet!

Jefff

Ugandan Knuckles

onfocus

Ricardo Milos

Ah That's Hawt

location

Ligma

Mafia

构造函数

dom破坏

Ok, Boomer


反射型 

Ma Spaghet!

<!-- 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

<!-- 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

<!-- 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

<!-- 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

<!-- 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

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

这里过滤了字母和数字

使用编码的方式

成功

Mafia

/* 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

<!-- 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换掉

 

成功

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • WPF打印控件内容
  • 嵌入式linux系统镜像制作day2
  • 软件工程概述(上)
  • 关注自闭症儿童:走进他们孤独的世界
  • CentOS7安装流程步骤详细教程
  • 数学建模预测类—【多元线性回归】
  • 【ARM】Cortex-A72技术手册(1)
  • c语言---文件
  • SQL每日一练-0816
  • CSS的:current伪类:精准定位当前活动元素
  • Kali Linux网络问题解决与静态IP配置技巧
  • uniapp webview子页面向父页面发送数据和触发事件,重点在第3条!!!
  • SpringBoot——整合Swagger
  • [Vue3 + TS + Vite]文件选择器-组件
  • vue3、uniapp-vue3模块自动导入
  • 网络传输文件的问题
  • 分享一款快速APP功能测试工具
  • [译] 怎样写一个基础的编译器
  • android图片蒙层
  • flutter的key在widget list的作用以及必要性
  • JavaScript实现分页效果
  • java小心机(3)| 浅析finalize()
  • Mysql5.6主从复制
  • node 版本过低
  • Node.js 新计划:使用 V8 snapshot 将启动速度提升 8 倍
  • node和express搭建代理服务器(源码)
  • webpack+react项目初体验——记录我的webpack环境配置
  • 回顾2016
  • 用Node EJS写一个爬虫脚本每天定时给心爱的她发一封暖心邮件
  • 06-01 点餐小程序前台界面搭建
  • No resource identifier found for attribute,RxJava之zip操作符
  • ionic入门之数据绑定显示-1
  • MyCAT水平分库
  • Spring第一个helloWorld
  • 阿里云服务器购买完整流程
  • #100天计划# 2013年9月29日
  • #android不同版本废弃api,新api。
  • #HarmonyOS:Web组件的使用
  • (1)虚拟机的安装与使用,linux系统安装
  • (10)工业界推荐系统-小红书推荐场景及内部实践【排序模型的特征】
  • (55)MOS管专题--->(10)MOS管的封装
  • (Matalb时序预测)PSO-BP粒子群算法优化BP神经网络的多维时序回归预测
  • (Ruby)Ubuntu12.04安装Rails环境
  • (附源码)springboot宠物管理系统 毕业设计 121654
  • (每日一问)操作系统:常见的 Linux 指令详解
  • (每日一问)设计模式:设计模式的原则与分类——如何提升代码质量?
  • (免费分享)基于springboot,vue疗养中心管理系统
  • (三)Kafka离线安装 - ZooKeeper开机自启
  • (十六)Flask之蓝图
  • (详细版)Vary: Scaling up the Vision Vocabulary for Large Vision-Language Models
  • (一)Java算法:二分查找
  • (一)WLAN定义和基本架构转
  • (转)用.Net的File控件上传文件的解决方案
  • (转载)VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
  • .Net Core webapi RestFul 统一接口数据返回格式