跨域

跨域的概念

從一個(gè)站點(diǎn)訪問一個(gè)資源,然后在這個(gè)資源當(dāng)中又去訪問另外的一個(gè)站點(diǎn)的資源帜篇,這個(gè)就是跨域糙捺。

同源

同源策略是瀏覽器的一種安全策略,所謂同源是指笙隙,域名洪灯,協(xié)議,端口完全相同竟痰。

跨域

不同源則跨域

例如http://www.example.com/

http://api.example.com/detail.html 不同源 域名不同
https://www.example.com/detail.html 不同源 協(xié)議不同
http://www.example.com:8080/detail.html 不同源 端口不同
http://api.example.com:8080/detail.html 不同源 域名签钩、端口不同
https://api.example.com/detail.html 不同源 協(xié)議、域名不同
https://www.example.com:8080/detail.html 不同源 端口凯亮、協(xié)議不同
http://www.example.com/detail/index.html 同源 只是目錄不同

解決跨域

jsonp

瀏覽器會(huì)阻止XMLHttpRequest跨域請(qǐng)求
但不會(huì)阻止script標(biāo)簽的跨域請(qǐng)求

// 當(dāng)前域:localhost:8080
<script src="http://www.jd.com" ></script>

創(chuàng)建script標(biāo)簽發(fā)送跨域請(qǐng)求边臼,并得到返回?cái)?shù)據(jù)(回調(diào)函數(shù))

$("#btn").on("click",function(){
    var script = document.createElement("script");
    script.src="http://www.jd.com/jd.php?callback=getInfo";
    document.body.apendChild(script);
}
funtion getInfo(obj){
    // 得到數(shù)據(jù)
    console.log(obj);
}

應(yīng)用:輸入框模糊搜索

window.onload=function(){
    document.getElementById("keyword").onkeyup=function(){
        if(this.value.length>0){
            var script=document.createElement("script");
            script.src="https://sug.so.#/suggest?callback=getInfo&encodein=utf-8&encodeout=utf-8&format=json&fields=word&word="+this.value;
            document.body.appendChild(script);
        }else{
            document.getElementsByClassName("area")[0].style.display="none";
        }
    }
}
function getInfo(obj){
    // 得到數(shù)據(jù) 解析到頁面
    console.log(obj);
}

jsonp 的跨域哄尔,它只支持get 方式的請(qǐng)求假消,因?yàn)樗鞘褂胹cript 標(biāo)簽去發(fā)送請(qǐng)求,而且服務(wù)端需要做處理岭接,客戶端也需要做處理富拗。如果跨域的時(shí)候傳遞的數(shù)據(jù)非常多臼予,jsonp 的方式就不太可取。

CORS 跨域(跨域資源共享)

前端發(fā)送請(qǐng)求時(shí)啃沪,服務(wù)器給一個(gè)響應(yīng)頭粘拾,告訴客戶端,這些數(shù)據(jù)可以訪問

header("Access-Control-Allow-Origin:*");

jsonp 與 cors 的區(qū)別

  • jsonp 是最早期的這種跨域解決方案

    • 因?yàn)槭鞘褂胹cript 標(biāo)簽發(fā)送請(qǐng)求创千,所以兼容性會(huì)比較好
    • 只支持 get方式
  • cors 是后期的一種解決方案

    • 它只需要改服務(wù)器的配置缰雇,客戶端不需要做任何的處理(一個(gè)響應(yīng)頭)
    • 兼容性稍微差一些,因?yàn)锳ccess-Control-Allow-Origin是后期http協(xié)議規(guī)定的
    • 支持get 追驴,以及post
  • 其它方式:通過后臺(tái)服務(wù)器轉(zhuǎn)發(fā)械哟,通過設(shè)置代理服務(wù)器

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市殿雪,隨后出現(xiàn)的幾起案子暇咆,更是在濱河造成了極大的恐慌,老刑警劉巖丙曙,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件爸业,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡亏镰,警方通過查閱死者的電腦和手機(jī)扯旷,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拆挥,“玉大人薄霜,你說我怎么就攤上這事≈酵茫” “怎么了惰瓜?”我有些...
    開封第一講書人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)汉矿。 經(jīng)常有香客問我崎坊,道長(zhǎng),這世上最難降的妖魔是什么洲拇? 我笑而不...
    開封第一講書人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任奈揍,我火速辦了婚禮,結(jié)果婚禮上赋续,老公的妹妹穿的比我還像新娘男翰。我一直安慰自己,他們只是感情好纽乱,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開白布蛾绎。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪租冠。 梳的紋絲不亂的頭發(fā)上鹏倘,一...
    開封第一講書人閱讀 51,482評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音顽爹,去河邊找鬼纤泵。 笑死,一個(gè)胖子當(dāng)著我的面吹牛镜粤,可吹牛的內(nèi)容都是我干的捏题。 我是一名探鬼主播,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼肉渴,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼涉馅!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起黄虱,我...
    開封第一講書人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤稚矿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后捻浦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體晤揣,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年朱灿,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了昧识。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡盗扒,死狀恐怖跪楞,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情侣灶,我是刑警寧澤甸祭,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站褥影,受9級(jí)特大地震影響池户,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜凡怎,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一校焦、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧统倒,春花似錦寨典、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽注暗。三九已至,卻和暖如春墓猎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背赚楚。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來泰國打工毙沾, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人宠页。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓左胞,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國和親举户。 傳聞我的和親對(duì)象是個(gè)殘疾皇子烤宙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354

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

  • 什么是跨域 跨域,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本俭嘁。它是由瀏覽器的同源策略造成的躺枕,是瀏覽器對(duì)JavaScript實(shí)...
    他方l閱讀 1,064評(píng)論 0 2
  • 什么是跨域 跨域,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本供填。它是由瀏覽器的同源策略造成的拐云,是瀏覽器對(duì)JavaScript實(shí)...
    Yaoxue9閱讀 1,299評(píng)論 0 6
  • 題目1.什么是同源策略? 同源策略(Same origin Policy): 瀏覽器出于安全方面的考慮,只允許與本...
    FLYSASA閱讀 1,721評(píng)論 0 6
  • 什么是跨域 跨域近她,是指瀏覽器不能執(zhí)行其他網(wǎng)站的腳本叉瘩。它是由瀏覽器的同源策略造成的,是瀏覽器對(duì)JavaScript實(shí)...
    HeroXin閱讀 836評(píng)論 0 4
  • http協(xié)議 Resource粘捎,URL薇缅,Request,Response攒磨,Headers http 請(qǐng)求的是資源R...
    Sharise_Mo佩珊閱讀 692評(píng)論 0 4