校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > html5 postMessage前端跨域并前端監聽的方法示例

html5 postMessage前端跨域并前端監聽的方法示例

熱門標簽:ok電銷機器人 地圖標注軟件打印出來 惡搞電話機器人 如何查看地圖標注 電話機器人技術 黃石ai電銷機器人呼叫中心 高德地圖標注商戶怎么標 欣鼎電銷機器人 效果 智能電銷機器人被禁用了么

有時候會遇到傻X需求,比如前端單點登陸!遇到需求,就要去想解決辦法,

這里我給大家做一個簡單的前端單點登陸的解決方案,

用到的就是postMessage跨域信息傳輸以及onstorage的監聽。

本文用到的知識點 koa架設靜態資源服務、跨域、postMessage的用法、onstorage監聽storage

第一步、架設兩個不同端口的服務

我們這里用koa2來搭建兩個服務到不同的端口,來模擬一下真正的工作中需要出現的跨域情況。

非常的簡單 主要用到 koa-static這個中間件
搭建起來也是非常容易的,如果大家想學node相關的知識 可以加我微信shouzi_1994 或者在博客下面留言你的聯系方式 這里就不多說廢話了 直接上代碼 視頻內會有詳細的搭建步驟

// localhost:4000
const Koa = require('koa');
const path = require('path')
const static = require('koa-static')
const app = new Koa();

//設置靜態資源的路徑 
const staticPath = './static'

app.use(static(
    path.join( __dirname,  staticPath)
  ))

  
console.log("服務啟動在4000端口")

app.listen(4000);


// localhost:3000
const Koa = require('koa');
const path = require('path')
const static = require('koa-static')
const app = new Koa();

//設置靜態資源的路徑 
const staticPath = './static'

app.use(static(
    path.join( __dirname,  staticPath)
  ))


console.log("服務啟動在4000端口")

app.listen(4000);

第二步、跨域通訊postMessage

我們首先來看一下 postMessage的API

otherWindow.postMessage(message, targetOrigin, [transfer]);

otherWindow
其他窗口的一個引用,比如iframe的contentWindow屬性、執行window.open返回的窗口對象、或者是命名過或數值索引的window.frames。

message
將要發送到其他 window的數據。它將會被結構化克隆算法序列化。這意味著你可以不受什么限制的將數據對象安全的傳送給目標窗口而無需自己序列化。[1]

targetOrigin
通過窗口的origin屬性來指定哪些窗口能接收到消息事件,其值可以是字符串""(表示無限制)或者一個URI。在發送消息的時候,如果目標窗口的協議、主機地址或端口這三者的任意一項不匹配targetOrigin提供的值,那么消息就不會被發送;只有三者完全匹配,消息才會被發送。這個機制用來控制消息可以發送到哪些窗口;例如,當用postMessage傳送密碼時,這個參數就顯得尤為重要,必須保證它的值與這條包含密碼的信息的預期接受者的origin屬性完全一致,來防止密碼被惡意的第三方截獲。如果你明確的知道消息應該發送到哪個窗口,那么請始終提供一個有確切值的targetOrigin,而不是。不提供確切的目標將導致數據泄露到任何對數據感興趣的惡意站點。

transfer 可選
是一串和message 同時傳遞的 Transferable 對象. 這些對象的所有權將被轉移給消息的接收方,而發送一方將不再保有所有權。

怎么樣是不是很容易理解,這里給大家中文化一下。

要傳輸的那個(父)子窗口.postMessage(傳輸的內容, 傳輸到哪個地址, [權限是否轉移(一般不用)]);

提前說一下,要想跨域傳輸,必須是父子頁面,也就是說,是通過js Open的頁面,或者ifream嵌套的頁面

好了 我們開始來寫代碼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
        <!-- postMessage和iframe解決普通的跨域問題 -->
    我是端口3000網站的內容
    <button onclick="send()">發消息給兒子</button>
    
    <iframe style="display:none" src="http://localhost:4000" frameborder="0"></iframe>
<script>
        function send() { 
                window.frames[0].postMessage({a:"1"},"http://localhost:4000"); // 觸發跨域子頁面的messag事件
        }

    window.addEventListener('message', function(event) {
        console.info('兒子來信了', event);
    }, false);
</script>
</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
        <!-- postMessage和iframe解決普通的跨域問題 -->
    我是端口4000網站的內容
    <button onclick="send()">發消息給爸爸</button>
    
    <iframe style="display:none" src="http://localhost:4000" frameborder="0"></iframe>
<script>
       window.addEventListener("message",function(event){
           console.log("爸爸來信了:", event)
        },false)

      function send() {
        parent.postMessage({a:1}, 'http://localhost:3000'); // 
     }
</script>
</body>
</html>

寫到這里我們已經實現了父子頁面的跨域通訊,但是這個通訊只發生在一個窗口內啊,并沒有達到我想要的效果,該怎么辦呢。

監聽數值變化,做出及時反應

到這里大家需要思考,什么東西是瀏覽器上的所有同域名網站都能看到的呢?

沒錯,storage,我們只需要對這個進行監聽就好了。

這里我們選擇監聽 loacalStorage 現在我們對子頁面做一下改進

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
        <!-- postMessage和iframe解決普通的跨域問題 -->
    我是端口4000網站的內容
    <button onclick="send()">發消息給爸爸</button>
    
    <iframe style="display:none" src="http://localhost:4000" frameborder="0"></iframe>
<script>
    
       window.addEventListener("message",function(event){
           console.log("爸爸來信了:", event)
           var data = JSON.stringify(event.data)
           window.localStorage.setItem("data",data)
        },false)

        window.onstorage(function(st){
            console.log(st.key,st.value)
        })
      function send() {
        parent.postMessage({a:1}, 'http://localhost:3000'); // 
     }

</script>

</body>
</html>

看,我們是不是到現在就能夠針對跨域傳輸的內容做出響應了呢?

思考

現在我們做到了兩個頁面的跨域通訊,那么三個到多個的跨域通訊怎么做呢?其實一個道理啦。現在道理說給你了,寫法自己去體驗一下吧。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:綏化 萍鄉 盤錦 聊城 中山 阿壩 金昌 赤峰

巨人網絡通訊聲明:本文標題《html5 postMessage前端跨域并前端監聽的方法示例》,本文關鍵詞  html5,postMessage,前端,跨域,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《html5 postMessage前端跨域并前端監聽的方法示例》相關的同類信息!
  • 本頁收集關于html5 postMessage前端跨域并前端監聽的方法示例的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    色狠狠色噜噜噜综合网| 视频一区二区国产| 亚洲高清免费视频| 美脚の诱脚舐め脚责91| gogo大胆日本视频一区| 日韩免费高清视频| 中文字幕视频一区二区三区久| 天天免费综合色| 91影院在线观看| 国产午夜亚洲精品羞羞网站| 亚洲女与黑人做爰| 国产不卡在线一区| 精品欧美一区二区久久| 亚洲国产另类精品专区| 99精品久久99久久久久| 久久色在线视频| 免费一区二区视频| 欧美人动与zoxxxx乱| 亚洲精品一二三区| 岛国精品一区二区| 久久久久久一二三区| 麻豆一区二区99久久久久| 欧美日韩一级片在线观看| 亚洲三级久久久| 成人久久久精品乱码一区二区三区| 日韩三区在线观看| 麻豆精品视频在线观看| 337p亚洲精品色噜噜狠狠| 亚洲一区在线观看免费 | 日欧美一区二区| 欧美日韩美少妇| 亚洲成人av电影在线| 91黄色激情网站| 一区二区在线观看不卡| 色狠狠桃花综合| 亚洲高清不卡在线| 欧美人xxxx| 另类人妖一区二区av| 欧美电影免费观看完整版| 狠狠色丁香久久婷婷综| 久久久精品蜜桃| 国产成人精品三级| √…a在线天堂一区| 日本韩国精品在线| 亚洲va韩国va欧美va| 91精品国产高清一区二区三区| 秋霞午夜鲁丝一区二区老狼| 91精品国产欧美日韩| 国产美女视频一区| 国产精品色婷婷| 91在线国产观看| 亚洲午夜三级在线| 91精品国产高清一区二区三区| 久久99精品国产麻豆不卡| 国产视频视频一区| 91福利在线免费观看| 日本系列欧美系列| 国产目拍亚洲精品99久久精品| 91视频在线看| 秋霞影院一区二区| 国产精品久久一卡二卡| 91蜜桃传媒精品久久久一区二区| 洋洋成人永久网站入口| 日韩女优视频免费观看| k8久久久一区二区三区 | 一区二区三区.www| 日韩精品专区在线| av资源站一区| 蜜桃视频在线观看一区二区| 精品国产三级a在线观看| 成人av网址在线| 无码av中文一区二区三区桃花岛| 精品国产91洋老外米糕| 99天天综合性| 久久精品国产在热久久| 亚洲美女在线国产| wwwwww.欧美系列| 在线国产亚洲欧美| 大桥未久av一区二区三区中文| 亚洲成av人片一区二区梦乃| 久久久www免费人成精品| 欧美日韩中文字幕一区| 成人av网在线| 极品尤物av久久免费看| 亚洲永久精品国产| 中文字幕精品在线不卡| 日韩一区二区三区三四区视频在线观看 | 国产成人激情av| 日韩av在线播放中文字幕| 综合av第一页| 日韩一区二区电影网| 91极品美女在线| 高清不卡一区二区在线| 天天色天天操综合| 亚洲国产精品久久久男人的天堂| 亚洲国产精品精华液ab| 91精品国产综合久久精品性色| 色婷婷综合久久久久中文一区二区| 国产一二三精品| 日韩成人免费电影| 亚洲va欧美va人人爽| 亚洲美女偷拍久久| 亚洲免费在线播放| 亚洲色图.com| 国产精品久久久久久亚洲毛片| 国产午夜精品久久久久久久| 精品美女被调教视频大全网站| 欧美疯狂性受xxxxx喷水图片| av综合在线播放| 99综合影院在线| 色88888久久久久久影院野外| 成人av网址在线| 91最新地址在线播放| 99久久久精品免费观看国产蜜| 国产一区不卡视频| 国产做a爰片久久毛片| 国产原创一区二区| 国产一区二区三区综合| 国内精品不卡在线| 国产成人自拍网| 国产白丝精品91爽爽久久 | 国产亚洲污的网站| 久久久久久久综合狠狠综合| 2023国产一二三区日本精品2022| 精品久久99ma| 国产日产欧美精品一区二区三区| 亚洲精品在线三区| 国产午夜精品一区二区| 国产精品成人免费在线| 亚洲精品久久7777| 亚洲图片欧美一区| 精品一区二区三区久久久| 国产成人在线免费| 色综合咪咪久久| 欧美高清hd18日本| 国产欧美日韩在线看| 中文字幕在线不卡一区 | 国产激情视频一区二区在线观看 | 中文字幕一区二区三区不卡在线 | 一区二区三区日韩欧美| 午夜一区二区三区视频| 免费人成精品欧美精品| 国产成人鲁色资源国产91色综| 成人国产精品免费| 欧美综合色免费| 精品欧美乱码久久久久久| 国产丝袜欧美中文另类| 国产精品盗摄一区二区三区| 亚洲va欧美va人人爽| 国产成人免费视频精品含羞草妖精| a在线播放不卡| 欧美一区二区精品| 中文字幕日韩一区| 日韩av高清在线观看| 成人免费毛片嘿嘿连载视频| 欧亚一区二区三区| 国产欧美日韩一区二区三区在线观看| 亚洲综合丁香婷婷六月香| 极品少妇xxxx偷拍精品少妇| 99r精品视频| 欧美变态凌虐bdsm| 亚洲精品日日夜夜| 国产一区999| 欧美一区二区播放| 亚洲夂夂婷婷色拍ww47| 国产一区二区影院| 日韩一区二区三区免费看 | 国产精品美女久久久久久2018| 午夜一区二区三区在线观看| 国产成人精品一区二区三区四区| 精品视频999| 亚洲免费av高清| 成人午夜免费电影| 久久一区二区三区四区| 午夜精品国产更新| 色婷婷av一区二区三区大白胸| 久久精品一区二区三区不卡| 亚洲一卡二卡三卡四卡五卡| 国产电影一区二区三区| 欧美一卡二卡三卡| 舔着乳尖日韩一区| 欧美日韩免费高清一区色橹橹| 最新国产の精品合集bt伙计| 国产毛片精品国产一区二区三区| 日韩一区二区高清| 免费观看在线色综合| 欧美日韩中文字幕一区| 亚洲一区二区在线视频| 91丝袜美女网| 自拍偷自拍亚洲精品播放| 成人黄色a**站在线观看| 国产精品美女一区二区| 成人午夜电影网站| 久久久精品免费观看| 国产成人综合视频| 欧美经典三级视频一区二区三区| 国产一区高清在线| 精品毛片乱码1区2区3区| 激情小说欧美图片| 久久免费视频色|