亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > 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前端跨域并前端監聽的方法示例的相關信息資訊供網民參考!
  • 推薦文章
    国产a毛片| 欧美一级视频免费观看| 99色播| 精品久久久久久免费影院| 四虎影视库| 国产91精品一区| 精品在线观看一区| 国产福利免费观看| 亚洲天堂在线播放| 精品视频在线观看一区二区三区| 国产麻豆精品视频| 一级女人毛片人一女人| 国产一区二区高清视频| 免费的黄视频| 久久国产精品只做精品| 久久国产精品只做精品| 亚洲精品久久玖玖玖玖| 天天做人人爱夜夜爽2020 | 韩国毛片免费| 在线观看成人网| 91麻豆精品国产高清在线| 国产精品自拍在线| 欧美大片毛片aaa免费看| 青草国产在线| 999久久久免费精品国产牛牛| a级黄色毛片免费播放视频| 日本特黄一级| 日韩中文字幕在线播放| 精品国产一区二区三区久久久蜜臀| 国产一区精品| 九九免费高清在线观看视频| 天天做日日爱夜夜爽| 国产视频一区在线| 青青青草视频在线观看| 91麻豆精品国产片在线观看| 黄色福利| 精品国产香蕉在线播出| 精品国产亚洲一区二区三区| 成人免费一级纶理片| 一 级 黄 中国色 片| 日本特黄特色aaa大片免费| 可以免费看污视频的网站| 日日夜人人澡人人澡人人看免| 在线观看成人网 | 欧美18性精品| 精品国产一区二区三区久久久蜜臀| 精品国产一区二区三区久久久蜜臀| 欧美激情影院| 九九免费高清在线观看视频| 精品美女| 精品在线观看国产| 久草免费在线色站| 深夜做爰性大片中文| 精品国产三级a| 你懂的福利视频| 韩国三级视频网站| a级毛片免费全部播放| 国产视频久久久| 欧美激情伊人| 成人免费网站视频ww| 日韩专区在线播放| 精品国产一区二区三区精东影业 | 国产福利免费视频| 久久99这里只有精品国产| 国产91精品露脸国语对白| 91麻豆精品国产高清在线| 日韩免费在线视频| 免费的黄视频| 中文字幕一区二区三区精彩视频| 免费国产在线观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品视频一区二区三区| 美女免费精品视频在线观看| 免费毛片基地| 欧美18性精品| 欧美爱爱网| 久久久久久久网| 日韩av片免费播放| 台湾毛片| 日韩免费片| 成人高清护士在线播放| 美女免费毛片| 九九久久99综合一区二区| 国产精品自拍在线观看| 青草国产在线| 国产麻豆精品免费密入口| 国产亚洲精品成人a在线| 日韩中文字幕一区二区不卡| 国产一区精品| a级精品九九九大片免费看| 青青青草视频在线观看| 免费的黄色小视频| 中文字幕Aⅴ资源网| 国产网站免费视频| 韩国三级香港三级日本三级| 美国一区二区三区| 日本伦理黄色大片在线观看网站| 夜夜操天天爽| 日韩在线观看免费| 免费国产在线观看不卡| 精品视频在线观看一区二区| 九九精品影院| 日韩男人天堂| 精品视频在线观看免费| 亚洲天堂在线播放| 国产一级强片在线观看| 久久99这里只有精品国产| 高清一级淫片a级中文字幕| 欧美大片毛片aaa免费看| 午夜欧美福利| 色综合久久天天综合| 精品久久久久久中文| 四虎久久影院| 天天色色色| 国产不卡高清在线观看视频| 一本高清在线| 欧美a免费| 青青青草影院 | 午夜激情视频在线播放| 麻豆系列 在线视频| 久久久久久久网| 天天做日日干| 久久国产精品自线拍免费| 国产一区国产二区国产三区| 国产精品自拍在线观看| 午夜在线亚洲| 在线观看成人网 | 免费国产在线视频| 精品国产香蕉伊思人在线又爽又黄| 亚洲精品久久玖玖玖玖| 黄色福利| 国产激情一区二区三区| 国产极品白嫩美女在线观看看| 欧美激情一区二区三区在线播放 | 日韩专区一区| 亚洲天堂免费| 欧美激情一区二区三区在线 | 台湾毛片| 免费国产在线视频| 九九九国产| 亚欧成人乱码一区二区| 久久精品人人做人人爽97| 国产成人精品综合在线| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 免费毛片基地| 日本在线www| 超级乱淫伦动漫| 国产国语对白一级毛片| 台湾毛片| 日韩男人天堂| 午夜精品国产自在现线拍| 免费的黄色小视频| 美女免费精品高清毛片在线视 | 欧美大片一区| 四虎影视久久| 999精品在线| 韩国三级一区| 九九久久国产精品| 久久精品道一区二区三区| 91麻豆精品国产高清在线| 精品在线视频播放| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美激情一区二区三区中文字幕| 国产精品免费久久| 99热精品在线| 成人影院一区二区三区| 91麻豆爱豆果冻天美星空| 久久99中文字幕| 99久久精品费精品国产一区二区| 四虎影视久久久| 精品国产一级毛片| 在线观看成人网 | 一级毛片视频免费| 欧美激情一区二区三区视频高清| 日韩男人天堂| 日韩一级精品视频在线观看| 精品视频在线看| 一级毛片视频播放| 日韩一级黄色片| 香蕉视频三级| 精品久久久久久免费影院| 国产一区二区精品久久91| 韩国毛片| 国产一区二区精品久久91| 日韩综合| 美女免费精品高清毛片在线视 | 国产一区二区精品久久| 午夜精品国产自在现线拍| 青青久久国产成人免费网站| 成人免费观看网欧美片| 免费国产在线观看| 亚飞与亚基在线观看| 国产网站免费观看| 精品久久久久久综合网| 亚洲第一页乱| 国产亚洲免费观看| 日韩免费在线观看视频| 日本免费乱人伦在线观看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 超级乱淫黄漫画免费|