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

使用DOM破坏启动xss

目录

实验环境:

分析:

找破坏点:

查看源码找函数:

找到了三个方法,loadComments、escapeHTM 、displayComments

loadComments

escapeHTM

displayComments:

GOGOGO 


实验环境:

Lab: Exploiting DOM clobbering to enable XSS | Web Security Academy (portswigger.net)

分析:

找破坏点:

第一个输入框可以看见是<texarrea>;不能插入语句.:

 构造一个语句试试

 <img src=1 οnerrοr=alert(1)>bxbxbxb

可以看到onerror被过滤掉了,所以就不能在这里注入了:

查看源码找函数:

主要看.js,因为js可能会出现DOM破坏的点;找到了这个东西,看看:

loadCommentsWithDomClobbering.js

找到了三个方法,loadComments、escapeHTM 、displayComments
loadComments

将   <>'"  过滤为实体编码;这意味着不会再走进标签开始状态,恶意代码不会在这生效了:

escapeHTM

XMLHttpRequest()这个类是js的请求方法的总结

建立了一个request请求,监听了一个onreadystatechange ,将返回的requesText用json进行解析,解析完后调用displayComments进行展示;

就是做一个提交然后解析后展示。

displayComments:
  1. 获取DOM元素:首先,通过document.getElementById("user-comments")获取一个HTML元素,这个元素将作为容器来显示所有的评论。

  2. 遍历评论数组:使用for循环遍历传入的comments数组,每个元素代表一个评论。

  3. 创建评论部分:对于每个评论,创建一个section元素,并设置其class属性为comment

  4. 创建段落元素:在section元素内部创建一个p元素,用于显示评论内容。

  5. 处理头像:获取评论中的头像URL,如果评论中没有提供头像URL,则使用默认头像。头像URL被插入到一个img标签中,并添加class="avatar"

  6. 创建头像容器:创建一个div元素,用于包含头像的img标签。

  7. 将头像添加到容器中:将头像的HTML代码添加到div元素中

发现问题:

如果没有头像的话会使用默认的头像 ,如果能去到defaultAvatar这里,就有可能闭合下面的src

let defaultAvatar = window.defaultAvatar || {avatar: '/resources/images/avatarDefault.svg'}
let avatarImgHTML = '<img class="avatar" src="' + (comment.avatar ? escapeHTML(comment.avatar) : defaultAvatar.avatar) + '">';

GOGOGO 

window.defaultAvatar这个东西可以创造,如何去创造呢?

根据前面的知识,这是一个两层的层级关系,我们可以用 HTMLCollection 来操作

<a id=defaultAvatar><a id=defaultAvatar name=avatar href="cid:&quot;onerror=alert(1)//">

这里注意  "  需要进行 HTML实体编码,用 URL 编码的话浏览器会报错

Failed to load resource: net::ERR_UNKNOWN_URL_SCHEME

这样评论以后我们可以在自己的评论处看到:

<a href="cid:&quot;onerror=alert(1)//" name="avatar" id="defaultAvatar"></a>

好像并没有实现:(需要再评论一次,再次获取头像时会被   ↑  这个覆盖掉)

cid:提交一个不存在的伪协议,后面的语句不会被编码为Unicode的形式去,会顺利的进入到HTML中,随着HTML解码被解出。

 

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • 机器学习-识别手写数字
  • 网络编程day8
  • 系统编程 网络 基于tcp协议
  • JavaScript_10_练习:轮播图
  • 深度学习--RNN以及RNN的延伸
  • 「数组」数组双指针算法合集:二路合并|逆向合并|快慢去重|对撞指针 / LeetCode 88|26|11(C++)
  • Golang | Leetcode Golang题解之第352题将数据流变为多个不相交区间
  • ROS 2中,CMakeList.txt常见语法
  • 【数据结构】二叉树的深度理解
  • 浅谈Winform
  • Qt程序比较字符串Qstring是否相等
  • day40——数据库 sqlite3
  • 这周末,除非外面下钞票,否则谁也拦不住我玩《黑神话悟空》(附:两款可以玩转悟空的显卡推荐)
  • Android 安卓Compose软键盘和Activity页面的协调处理问题
  • 【Prettier】代码格式化工具Prettier的使用和配置介绍
  • @jsonView过滤属性
  • 【许晓笛】 EOS 智能合约案例解析(3)
  • Android系统模拟器绘制实现概述
  • co.js - 让异步代码同步化
  • Java 最常见的 200+ 面试题:面试必备
  • Linux学习笔记6-使用fdisk进行磁盘管理
  • nginx 负载服务器优化
  • Python学习之路16-使用API
  • vue.js框架原理浅析
  • 第2章 网络文档
  • 工作手记之html2canvas使用概述
  • 海量大数据大屏分析展示一步到位:DataWorks数据服务+MaxCompute Lightning对接DataV最佳实践...
  • 基于Dubbo+ZooKeeper的分布式服务的实现
  • 记录:CentOS7.2配置LNMP环境记录
  • 简单易用的leetcode开发测试工具(npm)
  • 批量截取pdf文件
  • 前端js -- this指向总结。
  • 删除表内多余的重复数据
  • 深度解析利用ES6进行Promise封装总结
  • 微信小程序:实现悬浮返回和分享按钮
  • 在Docker Swarm上部署Apache Storm:第1部分
  • 白色的风信子
  • 7行Python代码的人脸识别
  • Android开发者必备:推荐一款助力开发的开源APP
  • Java数据解析之JSON
  • 新年再起“裁员潮”,“钢铁侠”马斯克要一举裁掉SpaceX 600余名员工 ...
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • #DBA杂记1
  • #Spring-boot高级
  • #宝哥教你#查看jquery绑定的事件函数
  • #我与Java虚拟机的故事#连载08:书读百遍其义自见
  • $.each()与$(selector).each()
  • (003)SlickEdit Unity的补全
  • (70min)字节暑假实习二面(已挂)
  • (9)YOLO-Pose:使用对象关键点相似性损失增强多人姿态估计的增强版YOLO
  • (C#)Windows Shell 外壳编程系列9 - QueryInfo 扩展提示
  • (C#)获取字符编码的类
  • (cljs/run-at (JSVM. :browser) 搭建刚好可用的开发环境!)
  • (el-Date-Picker)操作(不使用 ts):Element-plus 中 DatePicker 组件的使用及输出想要日期格式需求的解决过程
  • (Redis使用系列) SpringBoot中Redis的RedisConfig 二