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并不会执行。
这貌似就是我们想要的结果。
以上这篇js 监控iframe URL的变化实例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍JS实现移动端实时监听输入框变化的实例代码,包括了JS实现移动端实时监听输入框变化的实例代码的使用技巧和注意事项,需要的朋友参考一下 如果是在pc端,监听输入框你可能想到focus、blur、hover、onkeyup这些事件,但是如果是在移动端使用使用这些事件用户体验极差,因为你要用户收起键盘并且再点个空白处才生效,甚至还存在很大的兼容差异。那么怎么解决呢? 方案一 以前做一个简单
本文向大家介绍监控Nodejs的性能实例代码,包括了监控Nodejs的性能实例代码的使用技巧和注意事项,需要的朋友参考一下 下面给大家介绍下监控Nodejs的性能, 最近想监控一下Nodejs的性能。记录分析Log太麻烦,最简单的方式是记录每个HTTP请求的处理时间,直接在HTTP Response Header中返回。 记录HTTP请求的时间很简单,就是收到请求记一个时间戳,响应请求的时候再记一
本文向大家介绍AngularJS监听路由的变化示例代码,包括了AngularJS监听路由的变化示例代码的使用技巧和注意事项,需要的朋友参考一下 话不多说,我们下面直接来看实现的示例代码 【一】Angular 路由状态发生改变时可以通过' $stateChangeStart '、' $stateChangeSuccess '、' $stateChangeError '监听,通过注入'$locatio
本文向大家介绍python中文件变化监控示例(watchdog),包括了python中文件变化监控示例(watchdog)的使用技巧和注意事项,需要的朋友参考一下 在python中文件监控主要有两个库,一个是pyinotify ( https://github.com/seb-m/pyinotify/wiki ),一个是watchdog(http://pythonhosted.org/watchd
本文向大家介绍Java实现文件监控器FileMonitor的实例代码,包括了Java实现文件监控器FileMonitor的实例代码的使用技巧和注意事项,需要的朋友参考一下 应用场景: 代码可以实现文件变化后的监听,如文件变化,自动重新加载文件内容,实现配置文件的热部署。 代码: package com.yx.demo.filemonitor; 使用demo: 总结 以上所述是小编给大家介绍的J
本文向大家介绍python监控键盘输入实例代码,包括了python监控键盘输入实例代码的使用技巧和注意事项,需要的朋友参考一下 本文研究的主要是python监控键盘输入的相关代码,用到了os,sys,time等,具体实现代码如下: 结果: 总结 以上就是本文关于python监控键盘输入实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢