js 监控iframe URL的变化实例代码


Posted in Javascript onJuly 12, 2017

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 监控iframe URL的变化实例代码

安全情况:

js 监控iframe URL的变化实例代码

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

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

以上这篇js 监控iframe URL的变化实例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
浅析Prototype的模板类 Template
Dec 07 Javascript
多种方法判断Javascript对象是否存在
Sep 22 Javascript
ExtJS中设置下拉列表框不可编辑的方法
May 07 Javascript
JAVA四种基本排序方法实例总结
Jul 24 Javascript
jquery实现的淡入淡出下拉菜单效果
Aug 25 Javascript
使用JS轻松实现ionic调用键盘搜索功能(超实用)
Sep 06 Javascript
Angular学习笔记之angular的$filter服务浅析
Nov 12 Javascript
Bootstrap Img 图片样式(推荐)
Dec 13 Javascript
利用types增强vscode中js代码提示功能详解
Jul 07 Javascript
vue-cli webpack2项目打包优化分享
Feb 07 Javascript
vue@cli3项目模板怎么使用public目录下的静态文件
Jul 07 Javascript
基于postman获取动态数据过程详解
Sep 08 Javascript
jQuery 循环遍历改变a标签的href(实例讲解)
Jul 12 #jQuery
浅谈原生JS中的延迟脚本和异步脚本
Jul 12 #Javascript
基于zepto.js实现手机相册功能
Jul 11 #Javascript
React-Native实现ListView组件之上拉刷新实例(iOS和Android通用)
Jul 11 #Javascript
详解Webpack DLL用法以及功能
Jul 11 #Javascript
Bootstrap弹出框之自定义悬停框标题、内容和样式示例代码
Jul 11 #Javascript
node使用UEditor富文本编辑器的方法实例
Jul 11 #Javascript
You might like
用定制的PHP应用程序来获取Web服务器的状态信息
2006/10/09 PHP
利用递归把多维数组转为一维数组的函数
2006/10/09 PHP
Yii框架form表单用法实例
2014/12/04 PHP
初识laravel5
2015/03/02 PHP
CI(CodeIgniter)模型用法实例分析
2016/01/20 PHP
php redis实现文章发布系统(用户投票系统)
2017/03/04 PHP
laravel手动创建数组分页的实现代码
2018/06/07 PHP
PHP中通过getopt解析GNU C风格命令行选项
2019/11/18 PHP
javascript 处理HTML元素必须避免使用的一种方法
2009/07/30 Javascript
javascript中关于break,continue的特殊用法与介绍
2012/05/24 Javascript
struts2+jquery+json实现异步加载数据(自写)
2013/06/24 Javascript
喜大普奔!jQuery发布 3.0 最终版
2016/06/12 Javascript
JS实现快速的导航下拉菜单动画效果附源码下载
2016/11/01 Javascript
原生js实现水平方向无缝滚动
2017/01/10 Javascript
JS实现侧边栏鼠标经过弹出框+缓冲效果
2017/03/29 Javascript
jQuery实现Select下拉列表进行状态选择功能
2017/03/30 jQuery
nodejs个人博客开发第五步 分配数据
2017/04/12 NodeJs
Vue声明式渲染详解
2017/05/17 Javascript
基于Vue 2.0 监听文本框内容变化及ref的使用说明介绍
2018/08/24 Javascript
使用jquery的cookie实现登录页记住用户名和密码的方法
2019/03/13 jQuery
Node.js使用MongoDB的ObjectId作为查询条件的方法
2019/09/10 Javascript
JavaScript canvas实现跟随鼠标事件
2020/02/10 Javascript
[01:35]2018完美盛典章节片——共竞
2018/12/17 DOTA
[04:46]2018年度玩家喜爱的电竞媒体-完美盛典
2018/12/16 DOTA
python超简单解决约瑟夫环问题
2015/05/12 Python
Django中对通过测试的用户进行限制访问的方法
2015/07/23 Python
python 获取键盘输入,同时有超时的功能示例
2018/11/13 Python
python word转pdf代码实例
2019/08/16 Python
python__new__内置静态方法使用解析
2020/01/07 Python
绝对令人的惊叹的CSS3折叠效果(3D效果)整理
2012/12/30 HTML / CSS
新闻学专业大学生职业生涯规划范文
2014/03/02 职场文书
施工安全协议书范本
2014/09/26 职场文书
逃课打麻将检讨书
2014/10/05 职场文书
四风查摆剖析材料
2014/10/10 职场文书
2014年妇联工作总结
2014/11/21 职场文书
go结构体嵌套的切片数组操作
2021/04/28 Golang