婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

有時候會遇到傻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)會有詳細的搭建步驟

// localhost:4000
const 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:3000
const 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í)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:綏化 萍鄉(xiāng) 盤錦 聊城 中山 阿壩 金昌 赤峰

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《html5 postMessage前端跨域并前端監(jiān)聽的方法示例》,本文關(guān)鍵詞  html5,postMessage,前端,跨域,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《html5 postMessage前端跨域并前端監(jiān)聽的方法示例》相關(guān)的同類信息!
  • 本頁收集關(guān)于html5 postMessage前端跨域并前端監(jiān)聽的方法示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    6080yy午夜一二三区久久| 国产日韩精品久久久| 99久久亚洲一区二区三区青草 | 欧美另类z0zxhd电影| 精品成人一区二区| 国产精品久久99| 国产麻豆精品久久一二三| 成人在线一区二区三区| 91网站黄www| 色噜噜狠狠成人网p站| 蜜桃精品视频在线| 日日噜噜夜夜狠狠视频欧美人| 日韩美女精品在线| 国内外成人在线| 亚洲一区精品在线| 亚洲丝袜制服诱惑| 午夜精品久久久久久久蜜桃app| 综合分类小说区另类春色亚洲小说欧美| 在线播放一区二区三区| 亚洲少妇中出一区| 国产精品成人一区二区三区夜夜夜| 欧美一区二区三区性视频| 日韩欧美色综合| 欧美不卡一区二区三区四区| 欧美一卡2卡三卡4卡5免费| 精品裸体舞一区二区三区| 精品国产成人系列| 91.xcao| 中文字幕av资源一区| 亚洲国产精品久久人人爱| 亚洲欧美在线另类| 亚洲女同女同女同女同女同69| 亚洲欧美激情在线| 亚洲h在线观看| 国产成人午夜片在线观看高清观看 | 久久亚洲精品小早川怜子| 日韩精品一区二区三区视频播放| 久久麻豆一区二区| 国产精品灌醉下药二区| 亚洲欧美日韩国产另类专区| 中文字幕日本乱码精品影院| 亚洲福利视频一区二区| 亚洲一区二区三区四区不卡| 日本怡春院一区二区| 黄色日韩三级电影| 9l国产精品久久久久麻豆| 欧美在线综合视频| 久久av老司机精品网站导航| 在线中文字幕一区二区| 亚洲自拍欧美精品| 日韩免费成人网| 蜜桃在线一区二区三区| 国产成人在线影院| 日韩精品一区二区三区在线观看| 亚洲成在人线在线播放| 图片区小说区区亚洲影院| 成人黄色免费短视频| 欧美日韩一二三区| 91麻豆精品国产自产在线| 国产精品538一区二区在线| 成人国产精品免费观看| 欧美日本一道本| 亚洲一区欧美一区| 在线免费观看日本一区| 天堂av在线一区| 亚洲精品一区二区三区香蕉 | 一片黄亚洲嫩模| 亚洲va天堂va国产va久| 丁香亚洲综合激情啪啪综合| 欧美刺激脚交jootjob| 亚洲成年人影院| 日本不卡123| 狠狠色狠狠色综合系列| 91.com视频| 亚洲最新在线观看| 青青国产91久久久久久| 高清不卡一区二区在线| 国产亚洲欧美在线| www.久久精品| 美女一区二区三区在线观看| 国产精品美女久久福利网站| 一区二区三区四区五区视频在线观看| 久久九九久精品国产免费直播| 久久色在线观看| 中文字幕在线免费不卡| 亚洲一区日韩精品中文字幕| 天堂在线一区二区| 岛国精品一区二区| 色乱码一区二区三区88| 91美女福利视频| 日韩免费看的电影| 国产精品激情偷乱一区二区∴| 一卡二卡三卡日韩欧美| 看片的网站亚洲| 国产传媒日韩欧美成人| 91在线云播放| 欧美一区二区福利在线| 国产精品色眯眯| 免费日韩伦理电影| 色女孩综合影院| 日韩亚洲电影在线| 一区二区三区中文免费| 国产制服丝袜一区| 91麻豆精品国产91久久久久 | 欧美日韩一级二级| 精品国产免费视频| 一级中文字幕一区二区| 国产毛片一区二区| 在线成人免费视频| 欧美激情一区二区三区蜜桃视频| 中文字幕亚洲成人| 国产在线精品免费| 777久久久精品| 亚洲男人电影天堂| 国产一区999| 欧美群妇大交群的观看方式| 精品国产乱码久久久久久久 | 日韩欧美国产精品一区| 亚洲精品视频在线看| 国产一区二区在线看| 欧美色精品天天在线观看视频| 国产精品乱码人人做人人爱| 久久精品国产亚洲一区二区三区| 91在线精品一区二区三区| 久久久久成人黄色影片| 蜜臀av一区二区在线免费观看| 欧美亚洲禁片免费| 一区二区成人在线| 日本高清免费不卡视频| 最新中文字幕一区二区三区| 国产成a人亚洲精品| 精品久久久三级丝袜| 舔着乳尖日韩一区| 欧美伊人久久大香线蕉综合69| 国产精品国产三级国产专播品爱网 | 亚洲欧美视频一区| 成人小视频在线| 国产欧美一区二区在线| 国产成人综合在线| 中文字幕一区二区三区在线观看| 成人激情图片网| 中文字幕一区二区三区在线不卡 | 欧美日韩国产片| 水野朝阳av一区二区三区| 在线观看中文字幕不卡| 亚洲成人动漫在线免费观看| 欧美欧美午夜aⅴ在线观看| 国产麻豆精品在线观看| 久久久国产午夜精品| 成人午夜短视频| 亚洲欧美区自拍先锋| 欧美综合一区二区| 麻豆91精品视频| 中文字幕乱码亚洲精品一区| 91丨九色丨黑人外教| 亚洲亚洲精品在线观看| 日韩一区二区高清| 国产·精品毛片| 亚洲欧美影音先锋| 欧美亚洲精品一区| 激情av综合网| 一区二区三区av电影 | 亚洲高清在线视频| 精品国产污网站| 九九国产精品视频| 国产亚洲人成网站| 欧美日韩免费一区二区三区视频| 琪琪久久久久日韩精品| 国产欧美精品一区二区色综合朱莉 | 亚洲国产精品久久人人爱蜜臀| 日韩一区二区不卡| 91免费精品国自产拍在线不卡 | 亚洲图片有声小说| 久久伊99综合婷婷久久伊| 99国产精品国产精品久久| 亚州成人在线电影| 日韩三级视频中文字幕| 国产乱码精品一区二区三| 亚洲国产综合91精品麻豆| 久久久99精品免费观看不卡| 欧美亚洲丝袜传媒另类| 国产91在线观看| 捆绑变态av一区二区三区| 亚洲综合男人的天堂| 国产欧美日韩久久| 日韩欧美国产精品一区| 欧美三区在线视频| 成人av在线影院| 国产在线播精品第三| 亚洲成人激情自拍| 夜夜嗨av一区二区三区四季av| 国产肉丝袜一区二区| 欧美变态tickle挠乳网站| 欧美日韩一区久久| 99久久久免费精品国产一区二区| 国产激情91久久精品导航| av一二三不卡影片| 久久99国产精品麻豆| 日韩精品欧美精品| 无码av免费一区二区三区试看 |