js 监控iframe URL的变化

iframe的url可以前端任何地址,这样就可能出现漏洞,如果钓鱼网站通过js把src改成了危险地址,如果没有监控,就会有很大隐患。所以监控iframe的url变化就是必须要解决的问题了。

第一印象的解决方案是通过setInterval轮询监控,貌似不太理想了,而且有延迟。

千般搜索,终于找到了好的方法,可以通过H5新增的MutationObserver来解决,配合DOMAttrModified和onpropertychange来解决兼容性问题。

废话少说,直接上代码。

index.html代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <iframe id="iframeId" src="https://m.ppdai.com">
        
    </iframe>
    <script type="text/javascript" charset="utf-8" async defer>
        var  elemIframList =  document.getElementsByTagName('iframe');
        for(var i=0;i<elemIframList.length;i++){
            initIframeChange(elemIframList[i]);
        }
        function  initIframeChange(elemIfram)  {
            if (window.MutationObserver || window.webkitMutationObserver) {
                // chrome
                var callback = function(mutations) {
                    mutations.forEach(function(mutation) {
                        iframeSrcChanged(mutation.oldValue,mutation.target.src,mutation.target);
                    });
                };
                if (window.MutationObserver) {
                    var observer = new MutationObserver(callback);
                } else {
                    var observer = new webkitMutationObserver(callback);
                }
                observer.observe(elemIfram, {
                    attributes: true,
                    attributeOldValue: true
                });
            } else if (elemIfram.addEventListener) {
                // Firefox, Opera and Safari
                elemIfram.addEventListener("DOMAttrModified", function(event){iframeSrcChanged(event.prevValue,event.newValue,event.target);}, false);
            } else if (elemIfram.attachEvent) {
                // Internet Explorer
                elemIfram.attachEvent("onpropertychange", function(event){iframeSrcChanged(event.prevValue,event.newValue,event.target);});
            }
        }

        function  iframeSrcChanged(oldValue,newValue,iframeObj)  {
            console.log('旧地址:'+oldValue);
            console.log('新地址:'+newValue);
            if(newValue.indexOf('aaaa')>-1){
                console.log('有危险,请马上离开……')
                iframeObj.src=oldValue;//钓鱼地址,恢复原url
            }else{
                console.log('安全地址,允许跳转……');
            }
        }

        // 模拟方法
        function  simuChange()  {
            var  div  =  document.getElementById("iframeId");
            div.setAttribute("src", "aaaa.html");
        }
    </script>
</body>
</html>

aaaa.html代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    aaaaaaaa.html
    <script type="text/javascript" charset="utf-8" async defer>
        console.log('aaaa页面的js执行成功')        
    </script>
</body>
</html>

执行结果:

危险情况:

安全情况:

我们发现,如果跳转到危险页面,可以直接恢复旧页面,或者跳转指定安全页面,危险页面的js并不会执行。

这貌似就是我们想要的结果。

欢迎大家测试,并提出改进意见,谢谢!

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值