XSS高级 svg 复现一个循环问题以及两个循环问题

例子1:

源码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    
</body>
<script>
    const data = decodeURIComponent(location.hash.substring(1));
    const root = document.createElement('div');
    root.innerHTML = data;

    //这里模拟了xss过滤的过程,方法是移除所有属性
    for(let el of root.querySelectorAll('*')) {
     
        for (let attr of el.attributes) {
     
            el.removeAttribute(attr.name);
        }
    }

    document.body.appendChild(root);
</script>
</html>

因为现在是没有任何属性的,所以输出aaa

在这里插入图片描述

输入<script>alert(1)</script>这样的标签确实没有任何属性,但是源码中是innerHTML,所以只能用img标签
在这里插入图片描述

输入<img src="1" onerror="alert(1)">,发现把src属性删掉了
在这里插入图片描述

我们去断点调试一下,看看究竟为什么只删除了src属性,没有删除onerror属性

1、首先el是没有值的

在这里插入图片描述

2、el有值了,它是img,因为img传进来了
在这里插入图片描述

关键的是去看img中的attributes,有两个属性,一个src,一个onerror,看上去像数组一样的一个东西,有索引0和索引1。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值