<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
在Web開發中,為了避免安全漏洞,瀏覽器會實行同源策略(Same-Origin Policy),即只允許同源網頁之間進行互動,而跨域的互動是被禁止的。但是,有時我們需要在不同域名的頁面之間進行資料傳遞和互動。
通過 postMessage() 方法可以在兩個不同的視窗之間傳遞訊息,包括不同域名的 iframe。在父頁面中使用 postMessage() 方法傳送訊息,在子頁面中使用 addEventListener() 方法監聽訊息。需要注意的是,需要在兩個頁面中都新增相應的程式碼才能實現跨域互動。
在父頁面中:
// 傳送訊息到 iframe var iframe = document.getElementById('my-iframe'); iframe.contentWindow.postMessage('Hello from parent', '*'); // 接收子頁面發來的訊息 window.addEventListener('message', function(event) { if (event.origin !== 'http://example.com') return; // 驗證訊息來源 console.log('Received message from iframe:', event.data); }, false);
在子頁面中:
// 傳送訊息到父頁面 window.parent.postMessage('Hello from iframe', '*'); // 接收父頁面發來的訊息 window.addEventListener('message', function(event) { if (event.origin !== 'http://example.com') return; // 驗證訊息來源 console.log('Received message from parent:', event.data); }, false);
在父頁面中設定一個定時器,用於檢測目標頁面的URL雜湊值是否發生變化
setInterval(function() { if (document.getElementById("myIframe").contentWindow.location.hash) { // 子頁面URL雜湊值發生變化,執行相應的操作 } }, 100);
在子頁面中設定一個定時器,用於檢測父頁面URL雜湊值是否發生變化
setInterval(function() { if (window.location.hash) { // 父頁面URL雜湊值發生變化,執行相應的操作 } }, 100);
父頁面中通過改變iframe的src屬性來向目標頁面傳送訊息
document.getElementById("myIframe").src = "http://www.example.com/target-page#" + message;
子頁面中通過改變location.hash來向父頁面傳送訊息
window.location.hash = message;
使用location.hash和iframe進行跨域互動的方式存在一些限制和安全風險,例如URL雜湊值的長度限制、URL雜湊值被篡改等問題,因此需要謹慎使用,確保資料的安全性和完整性
子頁面中設定document.domain屬性,將其設定為父頁面的域名,以便子頁面和父頁面具有相同的域名,從而實現跨域互動。
document.domain = "example.com";
父頁面通過iframe元素的contentWindow屬性獲取子頁面的window物件,從而可以存取子頁面的內容和方法。
var iframe = document.getElementById("myFrame"); var childWindow = iframe.contentWindow;
子頁面可以通過window.parent屬性獲取父頁面的window物件,從而可以存取父頁面的內容和方法。
var parentWindow = window.parent;
注: 設定domain屬性是關鍵!!!
可以利用 iframe 的 window.name 屬性來進行跨域互動。由於 window.name 屬性在同一視窗中是唯一的,因此可以將需要傳遞的資料儲存在該屬性中,在父頁面中讀取。
在父頁面中:
<iframe id="myIframe" src="http://www.b.com"></iframe> <script> window.addEventListener('message', function(e) { // 處理從子頁面傳送過來的訊息 console.log(e.data); }); function onLoad() { var iframe = document.getElementById('myIframe'); var iframeWindow = iframe.contentWindow; // 獲取 iframe 的 window 物件 iframeWindow.name = 'hello from A'; // 在 iframe 的 window 物件中設定 name 屬性 } </script>
在子頁面中:
// 傳送訊息給父頁面 window.top.postMessage(window.name, 'http://www.a.com');
在子頁面中,我們設定了 window.name
的值,並使用 window.top.postMessage
方法向父頁面傳送訊息。在父頁面中,我們通過監聽 window.message
事件來接收這個訊息。注意,postMessage
方法中的第二個引數必須是父頁面的域名,否則瀏覽器會拒絕傳送訊息。
需要注意的是,使用 window.name 屬性進行跨域互動可能存在一些安全風險,因此需要謹慎使用,window.name也有2M容量的限制
CORS(Cross-Origin Resource Sharing)是一種跨域資源共用的機制,它通過在伺服器端設定響應頭來實現跨域通訊。通過在響應頭中設定 Access-Control-Allow-Origin、Access-Control-Allow-Methods 等欄位,可以允許指定的源、方法等跨域存取資源。在使用者端中,可以像存取同域資源一樣存取跨域資源。
JSONP 是一種通過動態新增 <script> 標籤來實現跨域通訊的方法。它的原理是在伺服器端返回一個函數呼叫,這個函數的引數是需要傳遞的資料。在使用者端中,通過動態建立 <script> 標籤並指定 src 屬性來呼叫這個函數,從而實現跨域通訊。需要注意的是,使用 JSONP 時需要信任提供資料的伺服器端,因為它會執行伺服器端返回的程式碼。
WebSocket 是一種雙向通訊協定,可以在使用者端和伺服器端之間建立一個持久化的連線。與 HTTP 不同,WebSocket 不會遵循同源策略,因此可以實現跨域通訊。在使用者端中,可以使用 WebSocket 物件與伺服器端建立連線,並通過 send() 方法傳送資料。在伺服器端中,可以監聽 WebSocket 連線,並在接收到使用者端的資料時進行處理。
WebRTC可以在不同域名下的瀏覽器之間直接傳輸資料,從而實現跨域通訊。
參考連結:如何基於 iframe 解決跨域?
到此這篇關於與iframe進行跨域互動的解決方案的文章就介紹到這了,更多相關iframe跨域互動內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45