亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

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

2024-08-26 00:21:08
字體:
來源:轉載
供稿:網友

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

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

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

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

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

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

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

// localhost:4000const 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:3000const 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>

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

思考

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

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品国产一区| 亚洲精品女av网站| 亚洲最大av网| 成人a在线观看| 国a精品视频大全| 91精品国产综合久久久久久久久| 欧美日韩国产综合新一区| 日韩www在线| 欧美电影免费观看网站| 九九精品视频在线观看| 国产精品av电影| 欧美在线观看视频| 亚洲精品电影在线观看| 欧美日韩色婷婷| 欧美大片免费观看在线观看网站推荐| 精品女厕一区二区三区| 欧美一区在线直播| 亚洲精品福利免费在线观看| 日韩av理论片| 78色国产精品| 狠狠躁夜夜躁久久躁别揉| 久久久亚洲影院你懂的| 欧美—级a级欧美特级ar全黄| 国产精品中文字幕在线观看| 国产精品久久久久高潮| 热99精品只有里视频精品| 日韩在线免费av| 91国在线精品国内播放| 成人xxxxx| 亚洲国产成人爱av在线播放| 国产精品福利久久久| 欧美日韩精品国产| 日韩美女av在线免费观看| 91精品国产91| 8x拔播拔播x8国产精品| 日韩精品亚洲精品| 日韩精品在线视频美女| 欧美日韩中文字幕综合视频| 精品亚洲一区二区三区在线观看| 深夜精品寂寞黄网站在线观看| 国产精品第3页| 亚洲www永久成人夜色| 国产精品第1页| 亚洲国产古装精品网站| 黑人巨大精品欧美一区二区三区| 亚洲精品影视在线观看| 亚洲第一精品电影| 亚洲天天在线日亚洲洲精| 国产69精品久久久久9999| 成人黄色免费网站在线观看| 亚洲欧美日韩一区在线| 久久久亚洲国产天美传媒修理工| 在线精品国产成人综合| 成人激情视频在线播放| 中文字幕日韩电影| 97久久伊人激情网| 成人福利在线观看| 17婷婷久久www| 久久成人精品电影| 国产99久久精品一区二区 夜夜躁日日躁| 国产精品久久久久国产a级| 97精品国产97久久久久久免费| 久久视频在线看| 中文字幕亚洲精品| 91精品在线一区| 欧美激情精品久久久久久免费印度| 久久精品视频导航| 欧美日韩成人免费| 欧美一区三区三区高中清蜜桃| 亚洲精品美女在线观看| 中文字幕在线观看日韩| 久久久精品久久久久| 国产午夜精品一区理论片飘花| 亚洲欧美精品一区| 国产精品免费电影| 亚洲国模精品一区| 国产91在线播放精品91| 欧美日韩在线视频一区| 色妞在线综合亚洲欧美| 中国日韩欧美久久久久久久久| 精品电影在线观看| 欧美日本高清一区| 亚洲视频日韩精品| 国产日本欧美一区二区三区在线| 欧美成人性色生活仑片| 国产精品亚发布| 国产精品影片在线观看| 57pao成人国产永久免费| www欧美xxxx| 91精品啪aⅴ在线观看国产| 91啪国产在线| 亚洲第一二三四五区| 亚洲毛片在线看| 亚洲激情在线观看视频免费| 欧美美女操人视频| 亚洲成成品网站| 亚洲区中文字幕| 久久精品国产一区二区三区| 日韩av在线影院| 亚洲色图偷窥自拍| 日韩精品视频免费专区在线播放| 日韩国产高清污视频在线观看| 精品久久久91| 中文字幕日韩在线播放| 色中色综合影院手机版在线观看| 国内精品国产三级国产在线专| 在线a欧美视频| 欧美性猛交xxxx免费看| 精品国产31久久久久久| 成人国产精品久久久久久亚洲| 欧美大片第1页| 欧美高清一级大片| 欧美三级xxx| 久久久久久综合网天天| 福利微拍一区二区| 97超级碰碰人国产在线观看| 欧美插天视频在线播放| 中文字幕亚洲激情| 国产日产久久高清欧美一区| 国产精品久久久久久久久久新婚| 久久国产精品久久久久久| 欧美成人免费va影院高清| 久久精品国产v日韩v亚洲| 日韩视频免费在线观看| 欧美亚洲在线视频| 欧美成人精品在线| 国产精品老牛影院在线观看| xvideos国产精品| 久久久久久免费精品| 中文字幕亚洲一区在线观看| 亚洲日本中文字幕免费在线不卡| 欧美一区二区三区图| 国产成人免费av电影| 色中色综合影院手机版在线观看| 亚洲影院色无极综合| 亚洲成人教育av| 精品久久久久久久大神国产| 亚洲jizzjizz日本少妇| 性欧美暴力猛交69hd| 亚洲欧美国产一区二区三区| 精品国偷自产在线视频| 欧美黑人性猛交| 国产在线观看精品一区二区三区| 国产精品爱久久久久久久| 欧美性videos高清精品| 95av在线视频| 91最新国产视频| 青青草精品毛片| 人人做人人澡人人爽欧美| 色偷偷综合社区| 亚洲国产99精品国自产| 日韩在线视频中文字幕| 亚洲午夜精品视频| 国产视频精品va久久久久久| 日韩视频―中文字幕| 日本国产欧美一区二区三区| 精品亚洲夜色av98在线观看| 欧美大尺度在线观看| 国产一区二区三区免费视频| 欧美亚洲另类在线| 91视频国产精品| 视频在线观看一区二区| 日韩高清人体午夜| 久久久久久久影视|