欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS跨域之window.name實(shí)現(xiàn)的跨域數(shù)據(jù)傳輸

 更新時(shí)間:2022年01月30日 11:10:57   投稿:wdc  
這篇文章主要介紹了JS跨域之window.name實(shí)現(xiàn)的跨域數(shù)據(jù)傳輸,需要的朋友可以參考下

一、 window.name的性質(zhì)

window.name有一個(gè)奇妙的性質(zhì),
頁面如果設(shè)置了window.name,那么在不關(guān)閉頁面的情況下,
即使進(jìn)行了頁面跳轉(zhuǎn)location.href=...,這個(gè)window.name還是會(huì)保留。

我們可以在控制臺(tái)做一下實(shí)驗(yàn):

// 打開瀏覽器輸入U(xiǎn)RL:www.dbjr.com.cn
//F12打開控制臺(tái)
//在控制臺(tái)中依次輸入下面內(nèi)容

//輸入
window.name;
//返回
''

//輸入
window.name='test';
//返回
'test'

//輸入
location.;
//返回
http://www.baidu.com

//輸入
window.name;
//返回
'test'

利用這一點(diǎn),我們就可以拿到其他域中的數(shù)據(jù)了。

二、 跨域請(qǐng)求

我們知道,使用iframesrc屬性,可以加載不同域中的網(wǎng)頁,
我們也可以使用$('iframe').contentWindow來拿到iframe中頁面的window對(duì)象,
只是這個(gè)window對(duì)象中可以訪問的屬性是很少的。

//控制臺(tái)輸入
Object.keys($('iframe').contentWindow);

//返回
["postMessage", "blur", "focus", "close", "parent", "opener", "top", "length", "frames", "closed", "location", "self", "window"]

訪問其他屬性,會(huì)報(bào)錯(cuò):

Uncaught DOMException: Blocked a frame with origin "..." from accessing a cross-origin frame.

而如果使用iframe加載同域的頁面,訪問$('iframe').contentWindow的屬性是不會(huì)報(bào)錯(cuò)的,它就是iframe內(nèi)頁面的完整的window對(duì)象。

三、整合

利用window.name的性質(zhì),我們可以在iframe中加載一個(gè)跨域頁面。

這個(gè)頁面載入之后,讓它設(shè)置自己的window.name,
然后再讓它進(jìn)行當(dāng)前頁面的跳轉(zhuǎn),跳轉(zhuǎn)到與iframe外的頁面同域的頁面,
此時(shí)window.name是不會(huì)改變的。

這樣,iframe內(nèi)外就屬于同一個(gè)域了,且window.name還是跨域的頁面所設(shè)置的值。

假設(shè)有三個(gè)頁面:

a.com/app.html:應(yīng)用頁面。

a.com/proxy.html:代理文件,一般是一個(gè)沒有任何內(nèi)容的html文件,需要和應(yīng)用頁面在同一域下。

b.com/data.html:應(yīng)用頁面需要獲取數(shù)據(jù)的頁面,可稱為數(shù)據(jù)頁面。

實(shí)現(xiàn)起來基本步驟如下:

在應(yīng)用頁面(a.com/app.html)中創(chuàng)建一個(gè)iframe,把其src指向數(shù)據(jù)頁面(b.com/data.html)。
數(shù)據(jù)頁面會(huì)把數(shù)據(jù)附加到這個(gè)iframe的window.name上,data.html代碼如下:

<script type="text/javascript">
    window.name = 'I was there!';    // 這里是要傳輸?shù)臄?shù)據(jù),大小一般為2M,IE和firefox下可以大至32M左右
                                     // 數(shù)據(jù)格式可以自定義,如json、字符串
</script>

在應(yīng)用頁面(a.com/app.html)中監(jiān)聽iframe的onload事件,在此事件中設(shè)置這個(gè)iframe的src指向本地域的代理文件(代理文件和應(yīng)用頁面在同一域下,所以可以相互通信)。app.html部分代碼如下:

<script type="text/javascript">
    var state = 0, 
    iframe = document.createElement('iframe'),
    loadfn = function() {
        if (state === 1) {
            var data = iframe.contentWindow.name;    // 讀取數(shù)據(jù)
            alert(data);    //彈出'I was there!'
        } else if (state === 0) {
            state = 1;
            iframe.contentWindow.location = "http://a.com/proxy.html";    // 設(shè)置的代理文件
        }  
    };
    iframe.src = 'http://b.com/data.html';
    if (iframe.attachEvent) {
        iframe.attachEvent('onload', loadfn);
    } else {
        iframe.onload  = loadfn;
    }
    document.body.appendChild(iframe);
</script>

獲取數(shù)據(jù)以后銷毀這個(gè)iframe,釋放內(nèi)存;這也保證了安全(不被其他域frame js訪問)。

<script type="text/javascript">
    iframe.contentWindow.document.write('');
    iframe.contentWindow.close();
    document.body.removeChild(iframe);
</script>

總結(jié)起來即:

iframe的src屬性由外域轉(zhuǎn)向本地域,跨域數(shù)據(jù)即由iframe的window.name從外域傳遞到本地域。這個(gè)就巧妙地繞過了瀏覽器的跨域訪問限制,但同時(shí)它又是安全操作。

參考文章:window.name TransportSession variables without cookies

另一篇 JS跨域(Access-Control-Allow-Origin)前后端解決方案詳解 有更詳細(xì)的關(guān)于瀏覽器跨域問題介紹

  • javascript去除字符串左右兩端的空格

    javascript去除字符串左右兩端的空格

    這篇文章主要介紹了javascript去除字符串左右兩端的空格,需要的朋友可以參考下
    2015-02-02
  • JavaScript面試開發(fā)常用的知識(shí)點(diǎn)總結(jié)

    JavaScript面試開發(fā)常用的知識(shí)點(diǎn)總結(jié)

    這篇文章主要為大家詳細(xì)總結(jié)了JavaScript面試開發(fā)常用的知識(shí)點(diǎn),感興趣的小伙伴們可以參考一下
    2016-08-08
  • 微信小程序基于高德地圖查找位置并顯示文字

    微信小程序基于高德地圖查找位置并顯示文字

    這篇文章主要介紹了微信小程序基于高德地圖查找位置并顯示文字,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • 下載網(wǎng)站打開頁面后間隔多少時(shí)間才顯示下載鏈接地址的代碼

    下載網(wǎng)站打開頁面后間隔多少時(shí)間才顯示下載鏈接地址的代碼

    有時(shí)候可能為了一些更好的廣告效果等原因,需要讓用戶等待一段時(shí)間以后,再顯示真實(shí)下載地址代碼,有利于緩解服務(wù)器壓力。
    2010-04-04
  • JavaScript中展開運(yùn)算符及應(yīng)用的實(shí)例代碼

    JavaScript中展開運(yùn)算符及應(yīng)用的實(shí)例代碼

    這篇文章主要介紹了JavaScript中展開運(yùn)算符及應(yīng)用的實(shí)例代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • JavaScript實(shí)現(xiàn)點(diǎn)擊按鈕就復(fù)制當(dāng)前網(wǎng)址

    JavaScript實(shí)現(xiàn)點(diǎn)擊按鈕就復(fù)制當(dāng)前網(wǎng)址

    在大量的網(wǎng)站都有這樣的功能,當(dāng)點(diǎn)擊一個(gè)按鈕的時(shí)候可以復(fù)制當(dāng)前頁面的地址,以此可以方便網(wǎng)站用戶對(duì)鏈接的存儲(chǔ),同時(shí)也便于網(wǎng)站的推廣,下面給大家分享具體實(shí)現(xiàn)代碼,對(duì)js實(shí)現(xiàn)點(diǎn)擊按鈕就復(fù)制的相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2015-12-12
  • JavaScript實(shí)現(xiàn)的一個(gè)計(jì)算數(shù)字步數(shù)的算法分享

    JavaScript實(shí)現(xiàn)的一個(gè)計(jì)算數(shù)字步數(shù)的算法分享

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)的一個(gè)計(jì)算數(shù)字步數(shù)的算法分享,本文先是講解了算法描述與實(shí)現(xiàn)原理,然后給出實(shí)現(xiàn)代碼,需要的朋友可以參考下
    2014-12-12
  • JavaScript實(shí)現(xiàn)簡易聊天對(duì)話框(加滾動(dòng)條)

    JavaScript實(shí)現(xiàn)簡易聊天對(duì)話框(加滾動(dòng)條)

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡易聊天對(duì)話框,附加滾動(dòng)條功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • 關(guān)于元素的尺寸(dimensions) 說明

    關(guān)于元素的尺寸(dimensions) 說明

    在使用JavaScript腳本獲取元素的尺寸時(shí),有幾個(gè)屬性你需要弄清楚,不然會(huì)很棘手。
    2011-09-09
  • 最新評(píng)論