欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2017年07月12日 08:12:00   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇js 監(jiān)控iframe URL的變化實(shí)例代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

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

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

千般搜索,終于找到了好的方法,可以通過(guò)H5新增的MutationObserver來(lái)解決,配合DOMAttrModified和onpropertychange來(lái)解決兼容性問(wèn)題。

廢話少說(shuō),直接上代碼。

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è)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript中的16進(jìn)制字符(改進(jìn))

    JavaScript中的16進(jìn)制字符(改進(jìn))

    后來(lái)經(jīng)過(guò)自己的測(cè)試,發(fā)現(xiàn)將字符轉(zhuǎn)換為十六進(jìn)制的方法不完善。
    2011-11-11
  • javascript中的數(shù)據(jù)類型檢測(cè)方法詳解

    javascript中的數(shù)據(jù)類型檢測(cè)方法詳解

    這篇文章主要介紹了javascript中的數(shù)據(jù)類型檢測(cè)方法,結(jié)合實(shí)例形式分析了javascript數(shù)據(jù)類型并總結(jié)分析了常見的數(shù)據(jù)類型檢測(cè)操作技巧,需要的朋友可以參考下
    2019-08-08
  • JavaScript注冊(cè)監(jiān)聽事件和清除監(jiān)聽事件方式詳解

    JavaScript注冊(cè)監(jiān)聽事件和清除監(jiān)聽事件方式詳解

    js中事件監(jiān)聽就是利用addEventListener來(lái)綁定一個(gè)事件,這個(gè)用法在jquery中非常常用并且簡(jiǎn)單,但在原生js中比較復(fù)雜,下面這篇文章主要給大家介紹了關(guān)于JavaScript注冊(cè)監(jiān)聽事件和清除監(jiān)聽事件方式的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • JavaScript 計(jì)算圖片加載數(shù)量的代碼

    JavaScript 計(jì)算圖片加載數(shù)量的代碼

    先定義一個(gè)圖片的數(shù)組,然后通過(guò)image的onload事件來(lái)計(jì)算,注意,onload在ie和火狐有所不同。
    2011-01-01
  • bootstrap基礎(chǔ)知識(shí)學(xué)習(xí)筆記

    bootstrap基礎(chǔ)知識(shí)學(xué)習(xí)筆記

    這篇文章主要針對(duì)bootstrap基礎(chǔ)知識(shí)為大家整理了詳細(xì)的學(xué)習(xí)筆記,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • javascript 實(shí)現(xiàn)子父窗體互相傳值的簡(jiǎn)單實(shí)例

    javascript 實(shí)現(xiàn)子父窗體互相傳值的簡(jiǎn)單實(shí)例

    本篇文章主要是對(duì)javascript 實(shí)現(xiàn)子父窗體互相傳值的簡(jiǎn)單實(shí)例進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2014-02-02
  • JavaScript AJAX之惰性載入函數(shù)

    JavaScript AJAX之惰性載入函數(shù)

    這篇文章主要介紹了JavaScript AJAX之惰性載入函數(shù),惰性載入表示函數(shù)執(zhí)行的分支僅會(huì)發(fā)生1次,是種JS的優(yōu)化技巧,需要的朋友可以參考下
    2014-08-08
  • 小程序?qū)崿F(xiàn)購(gòu)物車完整版

    小程序?qū)崿F(xiàn)購(gòu)物車完整版

    這篇文章主要為大家詳細(xì)介紹了小程序?qū)崿F(xiàn)購(gòu)物車完整版,實(shí)現(xiàn)加減計(jì)算數(shù)量跟金額,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • 詳解微信小程序?qū)崿F(xiàn)WebSocket心跳重連

    詳解微信小程序?qū)崿F(xiàn)WebSocket心跳重連

    這篇文章主要介紹了詳解微信小程序?qū)崿F(xiàn)WebSocket心跳重連,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • 淺談javascript函數(shù)式編程

    淺談javascript函數(shù)式編程

    你是否知道JavaScript其實(shí)也是一個(gè)函數(shù)式編程語(yǔ)言呢?本文將教你如何利用JavaScript的函數(shù)式特性。
    2015-09-09

最新評(píng)論