亚洲精品乱码久久久久蜜桃-97国产精品人妻无码久久久-加勒比中文字幕无码一区-中文字幕乱人伦高清视频-无码va在线观看

24小時咨詢電話:0571-88023217松原網(wǎng)站建設(shè)公司 10年專業(yè)網(wǎng)絡(luò)服務(wù)供應(yīng)商

資訊中心

- 直擊網(wǎng)站建設(shè)第一現(xiàn)場,掌握全球化的消息 -

當(dāng)前位置 : 首頁 > 資訊中心 > 如何用opener hack方式實現(xiàn)IE6,7完美跨域

如何用opener hack方式實現(xiàn)IE6,7完美跨域

分享 2012.03.23 瀏覽次數(shù):12100次

        有時我們做一個項目時,有需要跨域請求和處理一些大數(shù)據(jù)量得數(shù)據(jù),對于服務(wù)端提交的數(shù)據(jù)非常的之大,get的URL長度限制滿足不了需求,又由于跨域的影響,一直很頭痛數(shù)據(jù)傳輸?shù)膯栴}。于是乎,上網(wǎng)搜了搜一些跨域的解決方案,無非了iframe嵌iframe,通過window.name或者hash,做跳板,都受到url長度的限制,不是很理想。我們都知道在HTML5中,提供了一種postMessage的消息機制,可以在不同域的頁面上,互相通過window.postMessage(datastring,’limitDomain’)的方式傳遞消息。在需要觸發(fā)的頁面注冊onMessage事件,event的data屬性就是傳遞datastring文本。再配合老道的JSON.parse就可以完美的傳遞json格式的對象了。可惜的是目前PostMessage只在IE8,F(xiàn)F和Chrome現(xiàn)版本提供了實現(xiàn)。對于老版本的IE6,7沒有提供實現(xiàn)。

 

        于是在google搜索的時候,無意中發(fā)現(xiàn)某高人的Blog提供了一種稱之為IE6,7 opener hack的方式實現(xiàn)跨域,據(jù)說是google的工程師率先發(fā)現(xiàn)的這個bug,fackbook的登陸頁面就是利用了這個bug實現(xiàn)了postMessage的跨域。

可惜,google了半天,詳細資料基本找不到,也沒有找到一個具體的例子,于是自己搗鼓了一下,寫了個例子,放上來。

下面我們來看下,如何利用這個bug的例子

hosts配置

   1: 127.0.0.1    www.a.com
   2: 127.0.0.1    www.b.com

test.htm

   1:<html>
   2:<body>
   3:<iframeid="a"src="http://www.b.com/test1.htm">iframe>
   4:<script>
1:
   2:var i=document.getElementById('a');
   3: i.contentWindow.opener={
   4:     dd:function(str){
   5:var div=document.createElement('div');
   6:         document.body.appendChild(div);
   7:         div.innerHTML=str;
   8:     }
   9: }
  10: setTimeout(function(){
  11:     opener.bb('bbbbbbb');
  12: },300)
  13:
script>
   5:body>
   6:html>

test1.htm

   1:<html>
   2:<body>
   3:
   4:<script>
1:
   2:     window.opener.dd('aaaaaaaaa');
   3:     parent.opener={
   4:         bb:function(str){
   5:var div=document.createElement('div');
   6:             document.body.appendChild(div);
   7:             div.innerHTML=str;
   8:         }
   9:     }
script>
   5:body>
   6:
   7:html>

 

          我們可以看到,在IE6,7下,只要重置了window對象的opener為一個{}對象,在父頁面設(shè)置了iframe的window.opener為一個{}之后,在iframe里面就可以通過opener調(diào)用parent的方法,在iframe重置parent.opener為一個{}對象之后,在parent就可以調(diào)用iframe的方法。

*還有一種說法是可以設(shè)置opener為function(){},通過new opener()來調(diào)用

 

         總結(jié),通過IE6,7的hack,我們可以比較完美的實現(xiàn)postMessage在各大主流瀏覽器的兼容,以后跨域又多了一項利器。不過比較遺憾的事,重置opener之后,對于window.open打開的窗口,就不能很好的操作了。

杭州網(wǎng)站建設(shè)    相關(guān)閱讀:Chrome瀏覽器全球份額首次超過IE 但僅保持一天

最新網(wǎng)站案例

洞悉市場趨勢演變讓傳播回歸社會

    免費獲取網(wǎng)站建設(shè)與網(wǎng)絡(luò)推廣方案報價

    • 關(guān)于我們

      杭州帷拓科技有限公司,是一家新型的全案網(wǎng)絡(luò)開發(fā)公司,作為以互聯(lián)網(wǎng)高端網(wǎng)站建設(shè)、APP開發(fā)、小程序開發(fā)為核心的專業(yè)網(wǎng)絡(luò)技術(shù)服務(wù)供應(yīng)商,帷拓科技致力于全面分析市場環(huán)境、衡量與預(yù)測市場需求、整合區(qū)別于行業(yè)競爭對手的絕對優(yōu)勢,結(jié)合品牌理念深度挖掘項目優(yōu)勢和產(chǎn)品價值,提升客戶品牌認(rèn)知、認(rèn)可度。

    • 我們的客戶

      帷拓科技歷經(jīng)十年沉淀,與國內(nèi)外上千家客戶達成合作關(guān)系,其中穩(wěn)定合作的公司有:浙江華為、浙江移動、浙江5G產(chǎn)業(yè)聯(lián)盟、浙江省社科院、綠城足球俱樂部、娃哈哈雙語學(xué)校、健康中國杭州峰會、科雷機電等,帷拓科技始終堅持“帷有專業(yè),才能拓展無限”的服務(wù)理念,堅持“認(rèn)真堅持細節(jié)”的優(yōu)質(zhì)服務(wù)理念,不斷完善自身,成就企業(yè),最終實現(xiàn)共贏。

    • 我們的業(yè)務(wù)

      帷拓科技主營業(yè)務(wù)范圍包含互聯(lián)網(wǎng)高端網(wǎng)站建設(shè)、APP開發(fā)、小程序開發(fā)、商城網(wǎng)站建設(shè)、公眾號運營以及數(shù)字營銷等,涵蓋了服務(wù)、房產(chǎn)、數(shù)碼、服裝、物流貿(mào)易等行業(yè),根據(jù)品牌現(xiàn)狀,為每個客戶量身定制項目整體服務(wù)方案,以敏銳的市場洞察力、創(chuàng)新的市場策劃能力,全面把握市場變化,為客戶實現(xiàn)從企業(yè)到消費者的價值轉(zhuǎn)換。

    Designerpart Designagentur
    Designerpart Designagentur
    Designerpart Designagentur
    Designerpart Designagentur
    Designerpart Designagentur
    Designerpart Designagentur
    主站蜘蛛池模板: 2020无码天天喷水天天爽| 国产成人精品三级麻豆| 黄桃av无码免费一区二区三区| 性生交大片免费看女人按摩| 一本大道久久东京热无码av| 中文字幕亚洲综合小综合在线| 人妻系列无码专区免费视频| 日本一区二区三区免费播放| 日日天干夜夜人人添| 亚洲国产精品高清在线第1页| 亚洲另类欧美小说图片区| 人妻体内射精一区二区| 少妇熟女久久综合网色欲| 国产一区二区三区无码免费| 欧美日韩国产亚洲沙发| 亚洲欧美国产国产一区二区| 女人被狂c到高潮视频网站| 中文字幕v亚洲日本| 亚洲人成色777777老人头| 久久婷婷综合激情亚洲狠狠| 国产亚洲色视频在线| 日韩精品无码专区| 一本加勒比波多野结衣| 亚洲中文字幕人成影院| 无码人妻少妇伦在线电影| 亚洲国产精品无码专区| 国内精品久久人妻朋友| 无码精品视频| 欧洲性久久精品| 国产人妻人伦精品婷婷| 天天躁日日躁狠狠躁婷婷高清 | 亚洲a∨无码自慰专区| 亚洲欧美色国产综合| 亚洲国产精品一区二区久久hs | 麻豆亚洲国产成人精品无码区| 夜夜爽妓女8888视频免费观看| 色老久久精品偷偷鲁| 性色av一区二区三区咪爱四虎| 亚洲国产精品无码专区成人| 亚洲综合天天夜夜久久| 免费无码一区二区三区蜜桃大|