跨域AJAX解決方案

由于瀏覽器存在同源策略機制蜓竹,同源策略阻止從一個源加載的文檔或腳本獲取或設(shè)置另一個源加載的文檔的屬性荆几。

同源策略的判定規(guī)則:

如果兩個頁面擁有相同的協(xié)議蝶溶,端口嗜历,和主機,那么這兩個頁面就屬于同一個源抖所;

圖示例:


同源策略判定.png

特別的:由于同源策略是瀏覽器的限制梨州,所以請求的發(fā)送和響應是可以進行,只不過瀏覽器不接受罷了田轧。

瀏覽器同源策略并不是對所有的請求均制約:

  1. 制約: XmlHttpRequest
  2. 無效: img暴匠、iframe、script等具有src屬性的標簽

兩種實現(xiàn)跨域請求的方式傻粘,JSONP和CORS

對比:
Jsonp只支持 GET 請求每窖,CORS支持所有類型的HTTP請求帮掉。
Jsonp 的優(yōu)勢在于支持老式瀏覽器,以及可以向不支持CORS的網(wǎng)站請求數(shù)據(jù)岛请。

(1) JSON-P實現(xiàn)跨域請求

利用script標簽的src屬性(瀏覽器允許script標簽跨域)。

基本原理:

  1. 瀏覽器創(chuàng)建script標簽警绩,并利用script標簽的src屬性發(fā)送跨域請求崇败,獲取服務器的返回值在<script>標簽內(nèi)。
  2. 服務器返回函數(shù)調(diào)用語句(myfunc(args);)肩祥,并將需要返回的值(args)作為函數(shù)參數(shù)一并返回后室。
  3. 瀏覽器執(zhí)行服務器返回的調(diào)用函數(shù)的語句(myfunc(args)),對返回值進行操作。
  4. 瀏覽器刪除第一步創(chuàng)建的script標簽混狠。

代碼實例:

<p>
    <input type="button" onclick="getJsonp();"  value='提交'/>
</p>

JS實現(xiàn):

//創(chuàng)建script標簽跨域請求

function getJsonp(){
        var tag = document.createElement('script');
        tag.src = "http://tkq2.com:8000/test";
        document.head.appendChild(tag);
        document.head.removeChild(tag);
}

//根據(jù)返回函數(shù)myfunc([1,2,3]);執(zhí)行定義的myfunc函數(shù)
function  myfunc(list) {
    console.log(list);
}

Jquery實現(xiàn):
//創(chuàng)建script標簽跨域請求

function getJsonp(){
    $.ajax({
       url: "http://tkq2.com:8000/test",
       dataType: 'jsonp',
       jsonpCallback: 'myfunc'  
    })
}

其中jsonpCallback岸霹,自定義了回調(diào)函數(shù)名,默認為jQuery自動生成的隨機函數(shù)名将饺。如果不寫回調(diào)函數(shù)名贡避,默認執(zhí)行與服務器返回的函數(shù)名相同的函數(shù)。

//根據(jù)返回函數(shù)myfunc([1,2,3]);執(zhí)行定義的myfunc函數(shù)

function  myfunc(list) {
    console.log(list);
}

以上兩種寫法中予弧,回調(diào)函數(shù)被服務端寫死了刮吧,請求端必須定義和服務器端相同函數(shù)名才行。但作為服務端應該有更好的兼容性掖蛤,請求端自行決定回調(diào)函數(shù)名字杀捻。

JS實現(xiàn):
//創(chuàng)建script標簽跨域請求,并根據(jù)返回函數(shù)myfunc([1,2,3]);執(zhí)行定義的myfunc函數(shù)

function GetJsonp(){
    var tag = document.createElement('script');
    //自定義回調(diào)函數(shù)名蚓庭,jsonpcallback=myfunc字段供服務端讀取致讥。
    tag.src = "http://tkq2.com:8000/test?jsonpcallback=myfunc";
    document.head.appendChild(tag);
    document.head.removeChild(tag);
}

function  myfunc(list) {
    console.log(list);
}

Jquery實現(xiàn)

//創(chuàng)建script標簽跨域請求,并根據(jù)返回函數(shù)myfunc([1,2,3]);執(zhí)行定義的myfunc函數(shù)

function GetJsonp(){
    $.ajax({
        url: "http://tkq2.com:8000/test",
        dataType: 'jsonp',
        jsonp:'jsonpcallback',   //傳遞給請求處理程序或頁面的器赞,用以獲得jsonp回調(diào)函數(shù)名的參數(shù)名(一般默認為:callback)
        jsonpCallback:'myfunc'  //自定義了回調(diào)函數(shù)名垢袱,默認為jQuery自動生成的隨機函數(shù)名。如果不寫回調(diào)函數(shù)名港柜,默認執(zhí)行與服務器返回的函數(shù)名相同的函數(shù)惶桐。
    })
}

//回調(diào)函數(shù)

function  myfunc(list) {
    console.log(list);
}

(2) CORS跨域資源共享

隨著技術(shù)的發(fā)展,現(xiàn)在的瀏覽器可以支持主動設(shè)置從而允許跨域請求潘懊,即:跨域資源共享(CORS姚糊,Cross-Origin Resource Sharing),其本質(zhì)是設(shè)置響應頭授舟,使得瀏覽器允許跨域請求救恨。

這種實現(xiàn)方式:請求端和普通的AJAX方法相同,但服務器端需要做相應的配置释树。

跨域傳輸cookie:
在跨域請求中肠槽,默認情況下擎淤,HTTP Authentication信息,Cookie頭以及用戶的SSL證書無論在預檢請求中或是在實際請求都是不會被發(fā)送秸仙。

如果想要發(fā)送:

瀏覽器端:XMLHttpRequest的 withCredentials 為 true (如果后臺需要傳cookie嘴拢,則設(shè)置,否則寂纪,不用設(shè)置)
服務器端:Access-Control-Allow-Credentials 為 true

$.ajax({
    url: ajaxUrlConfig.getAddOrder,
    data: data,
    type: 'POST',
    xhrFields: {
        withCredentials: true
    },                
    dataType: 'json',
    timeout: 300000
});
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末席吴,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子捞蛋,更是在濱河造成了極大的恐慌孝冒,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拟杉,死亡現(xiàn)場離奇詭異庄涡,居然都是意外死亡,警方通過查閱死者的電腦和手機搬设,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進店門穴店,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人拿穴,你說我怎么就攤上這事迹鹅。” “怎么了贞言?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵斜棚,是天一觀的道長。 經(jīng)常有香客問我该窗,道長弟蚀,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任酗失,我火速辦了婚禮义钉,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘规肴。我一直安慰自己捶闸,他們只是感情好,可當我...
    茶點故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布拖刃。 她就那樣靜靜地躺著删壮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪兑牡。 梳的紋絲不亂的頭發(fā)上央碟,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天,我揣著相機與錄音均函,去河邊找鬼亿虽。 笑死菱涤,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的洛勉。 我是一名探鬼主播粘秆,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼收毫!你這毒婦竟也來了攻走?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤牛哺,失蹤者是張志新(化名)和其女友劉穎陋气,沒想到半個月后劳吠,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體引润,經(jīng)...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年痒玩,在試婚紗的時候發(fā)現(xiàn)自己被綠了淳附。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡蠢古,死狀恐怖奴曙,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情草讶,我是刑警寧澤洽糟,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站堕战,受9級特大地震影響坤溃,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜嘱丢,卻給世界環(huán)境...
    茶點故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一薪介、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧越驻,春花似錦汁政、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至并巍,卻和暖如春抠蚣,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背履澳。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工嘶窄, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留怀跛,地道東北人。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓柄冲,卻偏偏與公主長得像吻谋,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子现横,可洞房花燭夜當晚...
    茶點故事閱讀 45,435評論 2 359