跨域的主要方法

一、JSONP

利用<script>不受瀏覽器同源策略的限制特性,來跨域進(jìn)行引入資源璧眠,前提需要在自己項(xiàng)目中創(chuàng)建好接口足陨,協(xié)商好對方后端返回這個(gè)接口的調(diào)用并且給這個(gè)接口傳入?yún)?shù)嫂粟;
如下代碼:

位于http://a.com:9000/A.html的代碼:
HTML:
...
<div id="wrap">
        <h1>我是A站</h1>
        <button id="btn">點(diǎn)擊變顏色</button>
</div>
...
JS:
btn.addEventListener("click",fn);
function fn() {
    var script = document.createElement("script"); //動(dòng)態(tài)的創(chuàng)建一個(gè)script;
    script.src="http://b.com:8080/getcolor?type=setColor"; //設(shè)置請求的地址
    document.body.appendChild(script);
        }
function setColor(tinct){      //創(chuàng)建一個(gè)接口墨缘,當(dāng)請求返回這個(gè)接口的調(diào)用星虹;
     var h1 = document.querySelector("h1");   
     h1.style.color = tinct;
        }

效果圖如下:


這里有一個(gè)按鈕零抬,點(diǎn)擊之后標(biāo)題的顏色可以改變。http://b.com:8080/getcolor?type=setColor是一個(gè)需要請求的地址宽涌,這個(gè)地址將會(huì)返回一個(gè)接口的調(diào)用并給這個(gè)接口傳入?yún)?shù)setColor(color)平夜,這時(shí)就需要后端來提供了。
后端代碼如下:

位于http://b.com:8080/A.html的代碼(這里是nodejs的服務(wù)器):
function random(a,b){
            return a+Math.round(Math.random()*(b-a))
        }
function getRandColor(){
            var arr = ["#"];
            for (var i = 0; i < 3; i++) {
                arr.push(random(0,255).toString(16));
            }
            return arr.join("");
}      //這兩個(gè)方法將會(huì)返回一個(gè)隨機(jī)的十六進(jìn)制顏色碼卸亮;
···
            var color = getRandColor();
            var type = pathObj.query.type; //讀取請求連接里面的接口的函數(shù)名忽妒;
            res.end(type+"("+"'"+color+"'"+")");
           //返回一個(gè)函數(shù)的調(diào)用,這時(shí)將返回setColor('#******')兼贸;

效果如下:


二段直、CORS

與JSONP相比,CORS支持所有類型的HTTP請求而jsonp只支持GET請求溶诞。JSONP的優(yōu)勢在于支持老式瀏覽器鸯檬,以及可以向不支持CORS的網(wǎng)站請求數(shù)據(jù)。
同樣的需求這次使用CORS來進(jìn)行實(shí)現(xiàn)螺垢,這里需要我們使用Aajx來請求喧务。
前端代碼如下:

var btn = document.querySelector("#btn");
        btn.addEventListener("click",ajax);
var lock = false;   
        function ajax(){
            if (lock) {
                return;
            }
            var xhr = new XMLHttpRequest();
            xhr.open("get","http://b.com:8080/getcolor",true); 
           //這里請求的是B站的資源;
            xhr.send();
            lock = true;
            xhr.onload = function(){
                if ((xhr.status>=200&&xhr.status<300)||xhr.status===304) {
                    setColor(xhr.response);
                    lock = false;
                }
            }
        }
        function setColor(tinct){
            var h1 = document.querySelector("h1");
            h1.style.color = tinct;
        }

CORS的重點(diǎn)是后端代碼如下:

var color = getRandColor();//這里調(diào)用的函數(shù)枉圃,返回了一個(gè)十六進(jìn)制的顏色碼
res.setHeader("Access-Control-Allow-Origin", "*")
//設(shè)置響應(yīng)頭信息Access-Control-Allow-Origin為“*”
res.end(color);

后端把Access-Control-Allow-Origin設(shè)置為“*”功茴,意味著這可以允許所有的來訪問的域名;
效果如下:


三孽亲、降域

一個(gè)網(wǎng)頁嵌套了一個(gè)iframe指向另一個(gè)源坎穿,可以顯示里面的內(nèi)容但是無法使用js去操作它,如果想要js去操作里面的內(nèi)容墨林,并且是主域名和端口號相同的情況下赁酝,我們可以使用降域的方法去實(shí)現(xiàn)。
A站代碼如下:

<h1>我是A站</h1>
<iframe src="http://b.me.com:9000/b.html" id="into" name="B"></iframe>
//iframe 指向http://b.me.com:9000/b.html
 <button>點(diǎn)擊變顏色</button>
...
   document.querySelector('button').addEventListener('click', function(){
         var inner = window.frames["B"]
         inner.document.querySelector('h1').style.color = "red";
         inner.document.querySelector('p').innerText = "我被A站變成紅色的了";
})
       document.domain = "me.com";   將他們降域?yàn)閙e.com;

B站代碼如下:

<h1>我是B站</h1>
    <p></p>
...
document.domain = "me.com";
...

效果如下:



A站域名為a.me.com旭等、B站域名為b.me.com酌呆、利用document的domain屬性,將兩個(gè)域名同時(shí)設(shè)置為“me.com”搔耕,讓他們實(shí)現(xiàn)降域并且能跨域操作隙袁。
效果如下:


四、postMessage

這個(gè)是html5的新特性弃榨。相對于降域通過這個(gè)方法可以實(shí)現(xiàn)不同域名菩收、端口下的跨域操作,同樣實(shí)現(xiàn)上面的操作鲸睛,postMessage方法代碼如下:

A站代碼:
 document.querySelector('button').addEventListener('click', function(){
          inner.postMessage("red","http://b.com:8080/b.html")
})   //將向"http://b.com:8080/b.html"跨域發(fā)送“red”娜饵;
B站代碼:
window.addEventListener("message",function (e) {
            document.querySelector("h1").style.color = e.data;
        })

這里A站域名為a.com:9000,B站域名為b.ocm:8080,他們的域名和端口和是不同的也同樣實(shí)現(xiàn)了跨域操作,利用postMessage()方法官辈,這里它有兩個(gè)參數(shù)箱舞,第一個(gè)參數(shù)是所要發(fā)送的信息遍坟,第二個(gè)參數(shù)是需要發(fā)送的地址,在B站這里晴股,需要監(jiān)聽"message"時(shí)間愿伴,它所事件對象有三個(gè)重要的屬性:data代表了所傳過來的信息;origin發(fā)出請求的協(xié)議电湘、域名和端口號如http://a.com:9000隔节;source對發(fā)送消息的窗口對象的引用;
postMessage效果如下:

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市寂呛,隨后出現(xiàn)的幾起案子怎诫,更是在濱河造成了極大的恐慌,老刑警劉巖昧谊,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件刽虹,死亡現(xiàn)場離奇詭異,居然都是意外死亡呢诬,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進(jìn)店門胖缤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來尚镰,“玉大人,你說我怎么就攤上這事哪廓」钒Γ” “怎么了?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵涡真,是天一觀的道長分俯。 經(jīng)常有香客問我,道長哆料,這世上最難降的妖魔是什么缸剪? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮东亦,結(jié)果婚禮上杏节,老公的妹妹穿的比我還像新娘。我一直安慰自己典阵,他們只是感情好奋渔,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著壮啊,像睡著了一般嫉鲸。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上歹啼,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天玄渗,我揣著相機(jī)與錄音减江,去河邊找鬼。 笑死捻爷,一個(gè)胖子當(dāng)著我的面吹牛辈灼,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播也榄,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼巡莹,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了甜紫?” 一聲冷哼從身側(cè)響起降宅,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎囚霸,沒想到半個(gè)月后腰根,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡拓型,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年额嘿,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片劣挫。...
    茶點(diǎn)故事閱讀 39,779評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡册养,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出压固,到底是詐尸還是另有隱情球拦,我是刑警寧澤,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布帐我,位于F島的核電站坎炼,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏拦键。R本人自食惡果不足惜谣光,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望矿咕。 院中可真熱鬧抢肛,春花似錦、人聲如沸碳柱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽莲镣。三九已至福稳,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瑞侮,已是汗流浹背的圆。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工鼓拧, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人越妈。 一個(gè)月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓季俩,卻偏偏與公主長得像,于是被迫代替她去往敵國和親梅掠。 傳聞我的和親對象是個(gè)殘疾皇子酌住,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容