国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

js 監(jiān)控iframe URL的變化實(shí)例代碼

2019-11-19 16:06:22
字體:
供稿:網(wǎng)友

iframe的url可以前端任何地址,這樣就可能出現(xiàn)漏洞,如果釣魚網(wǎng)站通過js把src改成了危險(xiǎn)地址,如果沒有監(jiān)控,就會(huì)有很大隱患。所以監(jiān)控iframe的url變化就是必須要解決的問題了。

第一印象的解決方案是通過setInterval輪詢監(jiān)控,貌似不太理想了,而且有延遲。

千般搜索,終于找到了好的方法,可以通過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('有危險(xiǎn),請(qǐng)馬上離開……')        iframeObj.src=oldValue;//釣魚地址,恢復(fù)原url      }else{        console.log('安全地址,允許跳轉(zhuǎn)……');      }    }    // 模擬方法    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頁(yè)面的js執(zhí)行成功')      </script></body></html>

執(zhí)行結(jié)果:

危險(xiǎn)情況:

安全情況:

我們發(fā)現(xiàn),如果跳轉(zhuǎn)到危險(xiǎn)頁(yè)面,可以直接恢復(fù)舊頁(yè)面,或者跳轉(zhuǎn)指定安全頁(yè)面,危險(xiǎn)頁(yè)面的js并不會(huì)執(zhí)行。

這貌似就是我們想要的結(jié)果。

以上這篇js 監(jiān)控iframe URL的變化實(shí)例代碼就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 阿拉善左旗| 同德县| 疏勒县| 武胜县| 河东区| 濮阳县| 五家渠市| 泾阳县| 新宁县| 酒泉市| 永宁县| 沾化县| 随州市| 秭归县| 大邑县| 封丘县| 辛集市| 江孜县| 平南县| 德惠市| 屯门区| 沧州市| 寻乌县| 河西区| 永定县| 成都市| 乌苏市| 明水县| 防城港市| 洛扎县| 玉林市| 南安市| 西乌珠穆沁旗| 永州市| 徐汇区| 武山县| 青阳县| 新津县| 望城县| 余干县| 浦北县|