麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 開發(fā) > HTML5 > 正文

html5 postMessage前端跨域并前端監(jiān)聽的方法示例

2024-09-05 07:22:43
字體:
供稿:網(wǎng)友

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

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

用到的就是postMessage跨域信息傳輸以及onstorage的監(jiān)聽。

本文用到的知識點 koa架設(shè)靜態(tài)資源服務(wù)、跨域、postMessage的用法、onstorage監(jiān)聽storage

第一步、架設(shè)兩個不同端口的服務(wù)

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

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

// localhost:4000const Koa = require('koa');const path = require('path')const static = require('koa-static')const app = new Koa();//設(shè)置靜態(tài)資源的路徑 const staticPath = './static'app.use(static(    path.join( __dirname,  staticPath)  ))  console.log("服務(wù)啟動在4000端口")app.listen(4000);// localhost:3000const Koa = require('koa');const path = require('path')const static = require('koa-static')const app = new Koa();//設(shè)置靜態(tài)資源的路徑 const staticPath = './static'app.use(static(    path.join( __dirname,  staticPath)  ))console.log("服務(wù)啟動在4000端口")app.listen(4000);

第二步、跨域通訊postMessage

我們首先來看一下 postMessage的API

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

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

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

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

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

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

要傳輸?shù)哪莻€(父)子窗口.postMessage(傳輸?shù)膬?nèi)容, 傳輸?shù)侥膫€地址, [權(quán)限是否轉(zhuǎn)移(一般不用)]);

提前說一下,要想跨域傳輸,必須是父子頁面,也就是說,是通過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網(wǎng)站的內(nèi)容    <button onclick="send()">發(fā)消息給兒子</button>        <iframe style="display:none" src="http://localhost:4000" frameborder="0"></iframe><script>        function send() {                 window.frames[0].postMessage({a:"1"},"http://localhost:4000"); // 觸發(fā)跨域子頁面的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網(wǎng)站的內(nèi)容    <button onclick="send()">發(fā)消息給爸爸</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>

寫到這里我們已經(jīng)實現(xiàn)了父子頁面的跨域通訊,但是這個通訊只發(fā)生在一個窗口內(nèi)啊,并沒有達到我想要的效果,該怎么辦呢。

監(jiān)聽數(shù)值變化,做出及時反應(yīng)

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

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

這里我們選擇監(jiān)聽 loacalStorage 現(xiàn)在我們對子頁面做一下改進

<!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網(wǎng)站的內(nèi)容    <button onclick="send()">發(fā)消息給爸爸</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>

看,我們是不是到現(xiàn)在就能夠針對跨域傳輸?shù)膬?nèi)容做出響應(yīng)了呢?

思考

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 久久青草热| 精品久久久久久久 | 久草最新网址 | 久久久久久久久久综合 | 国产成人在线免费视频 | 九九热这里只有精品8 | 在线观看免费污视频 | 91色一区二区三区 | 国产成人自拍视频在线 | 国产成人精品二区 | 污黄视频在线观看 | 亚洲成人涩涩 | 国产精品刺激对白麻豆99 | 97久久日一线二线三线 | 九九热这里只有精品8 | 天天操很很操 | 欧美日韩免费看 | 久久久成人免费视频 | 欧洲成人综合网 | 色爱99 | 国产精品一区二区三区在线 | 综合精品视频 | 亚洲5区 | 国产美女的小嫩bbb图片 | 国产在线一级片 | 久久老司机 | 黄色毛片视频在线观看 | 国产女做a爱免费视频 | 羞羞的视频免费在线观看 | 欧美 videos粗暴 | 成人18免费观看 | 国产毛片毛片毛片 | 羞羞视频.www在线观看 | 综合精品一区 | 精品一区二区免费 | 日韩伦理电影免费观看 | 国产欧美精品综合一区 | 久久久久亚洲精品 | 色中色在线播放 | 激情九九 | 日韩毛片免费观看 |