跨域的解決方式及跨域的原理

跨域的原因

瀏覽器出于安全方面的考慮,只允許與本域下的接口交互么抗。不同源的客戶端腳本在沒有明確授權(quán)的情況下,不能讀寫對方的資源。

需要注意的是: 對于當(dāng)前頁面來說頁面存放的 JS 文件的域不重要泪喊,重要的是加載該 JS 頁面所在什么域

跨域的幾種方法

  1. JSOP
    JSONP是通過 script 標(biāo)簽加載數(shù)據(jù)的方式去獲取數(shù)據(jù)當(dāng)做 JS 代碼來執(zhí)行 提前在頁面上聲明一個函數(shù),函數(shù)名通過接口傳參的方式傳給后臺髓涯,后臺解析到函數(shù)名后在原始數(shù)據(jù)上「包裹」這個函數(shù)名袒啼,發(fā)送給前端。換句話說纬纪,JSONP 需要對應(yīng)接口的后端的配合才能實(shí)現(xiàn)蚓再。


    jsonp實(shí)例.png

本實(shí)例中點(diǎn)擊按鈕后創(chuàng)建 script 標(biāo)簽,通過js方式來獲取數(shù)據(jù)包各,數(shù)據(jù)解析過程如下:
從js文件中獲取到 news 中的數(shù)據(jù)后摘仅,先給文件添加數(shù)據(jù)類型以便瀏覽器判斷,然后再判斷是否使用callback函數(shù)髓棋,如果使用实檀,就通過JSON.stringify()方法將數(shù)組中的數(shù)據(jù)轉(zhuǎn)換成 一個JSON 字符串的值然后兩邊加上 ' ( ' 和 ' ) ' 并返回惶洲,再將發(fā)送數(shù)據(jù)通過 appendHtml 函數(shù)添加到 ul 標(biāo)簽中。

  1. CORS
    CORS 全稱是跨域資源共享(Cross-Origin Resource Sharing)膳犹,是一種 ajax 跨域請求資源的方式恬吕,支持現(xiàn)代瀏覽器,IE支持10以上须床。 實(shí)現(xiàn)方式很簡單铐料,當(dāng)你使用 XMLHttpRequest 發(fā)送請求時,瀏覽器發(fā)現(xiàn)該請求不符合同源策略豺旬,會給該請求加一個請求頭:Origin钠惩,后臺進(jìn)行一系列處理,如果確定接受請求則在返回結(jié)果中加入一個響應(yīng)頭:Access-Control-Allow-Origin; 瀏覽器判斷該相應(yīng)頭中是否包含 Origin 的值族阅,如果有則瀏覽器會處理響應(yīng)篓跛,我們就可以拿到響應(yīng)數(shù)據(jù),如果不包含瀏覽器直接駁回坦刀,這時我們無法拿到響應(yīng)數(shù)據(jù)愧沟。所以 CORS 的表象是讓你覺得它與同源的 ajax 請求沒啥區(qū)別,代碼完全一樣鲤遥。


    cors實(shí)例.png
res.setHeader('Access-Control-Allow-Origin','http://localhost:8080')
//允許localhost地址進(jìn)行跨域
res.setHeader('Access-Control-Allow-Origin','*')
//允許所有人使用這個數(shù)據(jù)
  1. 降域


    降域?qū)嵗?png

域名為http://b.jrg.com:8080/b.html的網(wǎng)頁以iframe的形式嵌在域名為http://a.jrg.com:8080/a.html的網(wǎng)頁中沐寺,它們來自不同的域名,正常情況下不能進(jìn)行跨域訪問盖奈。
但是當(dāng)我們?yōu)閮蓚€頁面都加上這樣一句代碼:
document.domain = 'jrg.com';
這時候這兩個頁面就位于同一個域名下面了混坞,就可以在頁面a中對頁面b進(jìn)行操作了,兩個頁面可以互相訪問钢坦。

但是這個方法有個限制究孕,就是兩個域名要有相同對的部分才可以,比如這個例子中的就都含有jrg.com這一部分场钉。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蚊俺,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子逛万,更是在濱河造成了極大的恐慌泳猬,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,451評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宇植,死亡現(xiàn)場離奇詭異得封,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)指郁,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,172評論 3 394
  • 文/潘曉璐 我一進(jìn)店門畦戒,熙熙樓的掌柜王于貴愁眉苦臉地迎上來寿弱,“玉大人,你說我怎么就攤上這事肛炮×仍海” “怎么了?”我有些...
    開封第一講書人閱讀 164,782評論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我项秉,道長,這世上最難降的妖魔是什么慷彤? 我笑而不...
    開封第一講書人閱讀 58,709評論 1 294
  • 正文 為了忘掉前任娄蔼,我火速辦了婚禮,結(jié)果婚禮上底哗,老公的妹妹穿的比我還像新娘岁诉。我一直安慰自己,他們只是感情好跋选,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,733評論 6 392
  • 文/花漫 我一把揭開白布涕癣。 她就那樣靜靜地躺著,像睡著了一般野建。 火紅的嫁衣襯著肌膚如雪属划。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,578評論 1 305
  • 那天候生,我揣著相機(jī)與錄音,去河邊找鬼绽昼。 笑死唯鸭,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的硅确。 我是一名探鬼主播目溉,決...
    沈念sama閱讀 40,320評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼菱农!你這毒婦竟也來了缭付?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,241評論 0 276
  • 序言:老撾萬榮一對情侶失蹤循未,失蹤者是張志新(化名)和其女友劉穎陷猫,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體的妖,經(jīng)...
    沈念sama閱讀 45,686評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绣檬,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,878評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了嫂粟。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片娇未。...
    茶點(diǎn)故事閱讀 39,992評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖星虹,靈堂內(nèi)的尸體忽然破棺而出零抬,到底是詐尸還是另有隱情镊讼,我是刑警寧澤,帶...
    沈念sama閱讀 35,715評論 5 346
  • 正文 年R本政府宣布平夜,位于F島的核電站蝶棋,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏褥芒。R本人自食惡果不足惜嚼松,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,336評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望锰扶。 院中可真熱鬧献酗,春花似錦、人聲如沸坷牛。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,912評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽京闰。三九已至颜及,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蹂楣,已是汗流浹背俏站。 一陣腳步聲響...
    開封第一講書人閱讀 33,040評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留痊土,地道東北人肄扎。 一個月前我還...
    沈念sama閱讀 48,173評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像赁酝,于是被迫代替她去往敵國和親犯祠。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,947評論 2 355

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