如何用opener hack方式實(shí)現(xiàn)IE6,7完美跨域
分享 2012.03.23 瀏覽次數(shù):7964次
有時(shí)我們做一個(gè)項(xiàng)目時(shí),有需要跨域請(qǐng)求和處理一些大數(shù)據(jù)量得數(shù)據(jù),對(duì)于服務(wù)端提交的數(shù)據(jù)非常的之大,get的URL長(zhǎng)度限制滿足不了需求,又由于跨域的影響,一直很頭痛數(shù)據(jù)傳輸?shù)膯栴}。于是乎,上網(wǎng)搜了搜一些跨域的解決方案,無(wú)非了iframe嵌iframe,通過window.name或者h(yuǎn)ash,做跳板,都受到url長(zhǎng)度的限制,不是很理想。我們都知道在HTML5中,提供了一種postMessage的消息機(jī)制,可以在不同域的頁(yè)面上,互相通過window.postMessage(datastring,’limitDomain’)的方式傳遞消息。在需要觸發(fā)的頁(yè)面注冊(cè)onMessage事件,event的data屬性就是傳遞datastring文本。再配合老道的JSON.parse就可以完美的傳遞json格式的對(duì)象了??上У氖悄壳癙ostMessage只在IE8,F(xiàn)F和Chrome現(xiàn)版本提供了實(shí)現(xiàn)。對(duì)于老版本的IE6,7沒有提供實(shí)現(xiàn)。
于是在google搜索的時(shí)候,無(wú)意中發(fā)現(xiàn)某高人的Blog提供了一種稱之為IE6,7 opener hack的方式實(shí)現(xiàn)跨域,據(jù)說是google的工程師率先發(fā)現(xiàn)的這個(gè)bug,fackbook的登陸頁(yè)面就是利用了這個(gè)bug實(shí)現(xiàn)了postMessage的跨域。
可惜,google了半天,詳細(xì)資料基本找不到,也沒有找到一個(gè)具體的例子,于是自己搗鼓了一下,寫了個(gè)例子,放上來(lái)。
下面我們來(lái)看下,如何利用這個(gè)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對(duì)象的opener為一個(gè){}對(duì)象,在父頁(yè)面設(shè)置了iframe的window.opener為一個(gè){}之后,在iframe里面就可以通過opener調(diào)用parent的方法,在iframe重置parent.opener為一個(gè){}對(duì)象之后,在parent就可以調(diào)用iframe的方法。
*還有一種說法是可以設(shè)置opener為function(){},通過new opener()來(lái)調(diào)用
總結(jié),通過IE6,7的hack,我們可以比較完美的實(shí)現(xiàn)postMessage在各大主流瀏覽器的兼容,以后跨域又多了一項(xiàng)利器。不過比較遺憾的事,重置opener之后,對(duì)于window.open打開的窗口,就不能很好的操作了。
杭州網(wǎng)站建設(shè) 相關(guān)閱讀:Chrome瀏覽器全球份額首次超過IE 但僅保持一天
-
杭州網(wǎng)站設(shè)計(jì)公司:品牌網(wǎng)站開發(fā)助力企業(yè)成長(zhǎng)
日期:2024-12-20瀏覽次數(shù):308次
-
杭州網(wǎng)站建設(shè)公司:商城網(wǎng)站建設(shè)的六大關(guān)鍵步驟
日期:2024-12-18瀏覽次數(shù):410次
-
杭州網(wǎng)站制作:醫(yī)院網(wǎng)站設(shè)計(jì)與域名備案的復(fù)雜性探討
日期:2024-12-18瀏覽次數(shù):422次
-
杭州網(wǎng)站制作公司:打造安全可靠的醫(yī)院網(wǎng)站
日期:2024-12-11瀏覽次數(shù):664次
-
杭州網(wǎng)站設(shè)計(jì)公司:數(shù)據(jù)庫(kù)在高端網(wǎng)站制作中的關(guān)鍵作用
日期:2024-12-11瀏覽次數(shù):639次
相關(guān)新聞
整合同類新聞,相關(guān)新聞一手掌握
-
臨安網(wǎng)站優(yōu)化:網(wǎng)站設(shè)計(jì)之整體形象設(shè)計(jì)新技巧
日期:2020-10-10瀏覽次數(shù):1851次
-
臨安網(wǎng)頁(yè)設(shè)計(jì):網(wǎng)站建設(shè)專業(yè)性主要體現(xiàn)在哪些方面
日期:2020-10-10瀏覽次數(shù):1832次
最新新聞
與互聯(lián)網(wǎng)同行,實(shí)時(shí)掌握網(wǎng)建行業(yè)最新動(dòng)態(tài)
-
網(wǎng)站建設(shè)之10個(gè)批量圖像處理工具分享
日期:2012-01-09瀏覽次數(shù):7905次
-
為什么Dart比JavaScript更酷
日期:2012-01-12瀏覽次數(shù):8458次
-
哪些因素會(huì)影響廣安app開發(fā)的價(jià)格
日期:2020-11-03瀏覽次數(shù):1838次
-
杭州網(wǎng)站優(yōu)化應(yīng)該怎樣規(guī)劃?
日期:2021-07-20瀏覽次數(shù):3937次
-
杭州開發(fā)app通過哪些方法盈利?
日期:2021-11-15瀏覽次數(shù):3633次
隨機(jī)新聞
新聞新動(dòng)態(tài),您需要的新聞管家
洞悉市場(chǎng)趨勢(shì)演變讓傳播回歸社會(huì)
免費(fèi)獲取網(wǎng)站建設(shè)與網(wǎng)絡(luò)推廣方案報(bào)價(jià)
-
關(guān)于我們
杭州帷拓科技有限公司,是一家新型的全案網(wǎng)絡(luò)開發(fā)公司,作為以互聯(lián)網(wǎng)高端網(wǎng)站建設(shè)、APP開發(fā)、小程序開發(fā)為核心的專業(yè)網(wǎng)絡(luò)技術(shù)服務(wù)供應(yīng)商,帷拓科技致力于全面分析市場(chǎng)環(huán)境、衡量與預(yù)測(cè)市場(chǎng)需求、整合區(qū)別于行業(yè)競(jìng)爭(zhēng)對(duì)手的絕對(duì)優(yōu)勢(shì),結(jié)合品牌理念深度挖掘項(xiàng)目?jī)?yōu)勢(shì)和產(chǎn)品價(jià)值,提升客戶品牌認(rèn)知、認(rèn)可度。
-
我們的客戶
帷拓科技?xì)v經(jīng)十年沉淀,與國(guó)內(nèi)外上千家客戶達(dá)成合作關(guān)系,其中穩(wěn)定合作的公司有:浙江華為、浙江移動(dòng)、浙江5G產(chǎn)業(yè)聯(lián)盟、浙江省社科院、綠城足球俱樂部、娃哈哈雙語(yǔ)學(xué)校、健康中國(guó)杭州峰會(huì)、科雷機(jī)電等,帷拓科技始終堅(jiān)持“帷有專業(yè),才能拓展無(wú)限”的服務(wù)理念,堅(jiān)持“認(rèn)真堅(jiān)持細(xì)節(jié)”的優(yōu)質(zhì)服務(wù)理念,不斷完善自身,成就企業(yè),最終實(shí)現(xiàn)共贏。
-
我們的業(yè)務(wù)
帷拓科技主營(yíng)業(yè)務(wù)范圍包含互聯(lián)網(wǎng)高端網(wǎng)站建設(shè)、APP開發(fā)、小程序開發(fā)、商城網(wǎng)站建設(shè)、公眾號(hào)運(yùn)營(yíng)以及數(shù)字營(yíng)銷等,涵蓋了服務(wù)、房產(chǎn)、數(shù)碼、服裝、物流貿(mào)易等行業(yè),根據(jù)品牌現(xiàn)狀,為每個(gè)客戶量身定制項(xiàng)目整體服務(wù)方案,以敏銳的市場(chǎng)洞察力、創(chuàng)新的市場(chǎng)策劃能力,全面把握市場(chǎng)變化,為客戶實(shí)現(xiàn)從企業(yè)到消費(fèi)者的價(jià)值轉(zhuǎn)換。