跨域問(wèn)題

本質(zhì)原因是同源策略狂男,瀏覽器會(huì)檢查 域名協(xié)議端口综看。
注意請(qǐng)求可以發(fā)過(guò)去,接收也可以岖食,但是被瀏覽器阻止了红碑。
瀏覽器為什么會(huì)阻止呢?原因是跨域泡垃,XHR(XMLHttpRequest) 請(qǐng)求
有兩種方式可以解決

  • jsonp
    前端利用 script 標(biāo)簽去請(qǐng)求析珊。如果利用 ajax 的方式去請(qǐng)求呢,其實(shí)就是往頁(yè)面中添加 script 標(biāo)簽蔑穴。這樣的話(huà)忠寻,請(qǐng)求類(lèi)型是 script 類(lèi)型,這樣瀏覽器就不會(huì)禁止了存和。
function test(arg) {
  var data=JSON.parse(arg);
}
function get_jsonp_data(url) {
  var ele_script=$("<script>");
  ele_script.attr("src": url);
  ele_script.attr("id", "jsonp");
  $("body").append(ele_script);
  $("#jsonp").remove()
}
// 點(diǎn)擊一個(gè) button 來(lái)請(qǐng)求
$(".get_service").click(function() {
  $.ajax({
    url: 'url',
    dataType: 'jsonp',
    jsonp:'callbacks',
    // jsonpCallback:"test",    指定具體回調(diào)函數(shù)锡溯,jquery 會(huì)隨機(jī)生成字符串
    success: function (data) {
      console.log()
    }
  })
});
// 服務(wù)器解析然后返回字符串
-------------->>>> server >>>>--------------
func = request.GET.get('callbacks')
r = {"name": 'asd', "age", 23}
return HttpResponse("%s(%s)"%(func, json.dumps(info)))
// 這里 func 相當(dāng)于 test
// 然后返回給瀏覽器一串字符,瀏覽器解析 script 標(biāo)簽進(jìn)行 函數(shù)調(diào)用哑姚,相當(dāng)于 test(r)
  • CORS
    又分為簡(jiǎn)單請(qǐng)求和復(fù)雜請(qǐng)求
    只要滿(mǎn)足以下條件祭饭,就屬于簡(jiǎn)單請(qǐng)求

(1) 請(qǐng)求方法是以下三種方法之一:HEAD GET POST
(2)HTTP的頭信息不超出以下幾種字段:
Accept Accept-Language
Content-Language Last-Event-ID
Content-Type:只限于三個(gè)值application/x-www-form-urlencodedmultipart/form-data叙量、text/plain
兩者區(qū)別
簡(jiǎn)單請(qǐng)求:一次請(qǐng)求
非簡(jiǎn)單請(qǐng)求:兩次請(qǐng)求倡蝙,在發(fā)送數(shù)據(jù)之前會(huì)先發(fā)一次請(qǐng)求用于做“預(yù)檢”,只有“預(yù)檢”通過(guò)后才再發(fā)送一次請(qǐng)求用于數(shù)據(jù)傳輸绞佩。

  • 關(guān)于“預(yù)檢”
    請(qǐng)求方式:OPTIONS
    “預(yù)檢”其實(shí)做檢查寺鸥,檢查如果通過(guò)則允許傳輸數(shù)據(jù)猪钮,檢查不通過(guò)則不再發(fā)送真正想要發(fā)送的消息
  • 如何“預(yù)檢”
    => 如果復(fù)雜請(qǐng)求是PUT等請(qǐng)求,則服務(wù)端需要設(shè)置允許某請(qǐng)求胆建,否則“預(yù)檢”不通過(guò)
    Access-Control-Request-Method
    => 如果復(fù)雜請(qǐng)求設(shè)置了請(qǐng)求頭烤低,則服務(wù)端需要設(shè)置允許某請(qǐng)求頭,否則“預(yù)檢”不通過(guò)
    Access-Control-Request-Headers
  • 支持跨域笆载,簡(jiǎn)單請(qǐng)求
    服務(wù)器設(shè)置響應(yīng)頭:Access-Control-Allow-Origin = '域名' 或 '*'
# Django 的返回
ret = HttpResponse()
ret["Access-Control-Allow-Origin"] = "域名"
return ret
  • 支持跨域扑馁,復(fù)雜請(qǐng)求
    由于復(fù)雜請(qǐng)求時(shí),首先會(huì)發(fā)送“預(yù)檢”請(qǐng)求凉驻,如果“預(yù)檢”成功腻要,則發(fā)送真實(shí)數(shù)據(jù)。
    “預(yù)檢”請(qǐng)求時(shí)涝登,允許請(qǐng)求方式則需服務(wù)器設(shè)置響應(yīng)頭:Access-Control-Request-Method
    “預(yù)檢”請(qǐng)求時(shí)雄家,允許請(qǐng)求頭則需服務(wù)器設(shè)置響應(yīng)頭:Access-Control-Request-Headers
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市胀滚,隨后出現(xiàn)的幾起案子趟济,更是在濱河造成了極大的恐慌,老刑警劉巖咽笼,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件咙好,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡褐荷,警方通過(guò)查閱死者的電腦和手機(jī)勾效,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)叛甫,“玉大人层宫,你說(shuō)我怎么就攤上這事∑浼啵” “怎么了萌腿?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)抖苦。 經(jīng)常有香客問(wèn)我毁菱,道長(zhǎng),這世上最難降的妖魔是什么锌历? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任贮庞,我火速辦了婚禮,結(jié)果婚禮上究西,老公的妹妹穿的比我還像新娘窗慎。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布遮斥。 她就那樣靜靜地躺著峦失,像睡著了一般。 火紅的嫁衣襯著肌膚如雪术吗。 梳的紋絲不亂的頭發(fā)上尉辑,一...
    開(kāi)封第一講書(shū)人閱讀 49,079評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音较屿,去河邊找鬼隧魄。 笑死,一個(gè)胖子當(dāng)著我的面吹牛吝镣,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播昆庇,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼末贾,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了整吆?” 一聲冷哼從身側(cè)響起拱撵,我...
    開(kāi)封第一講書(shū)人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎表蝙,沒(méi)想到半個(gè)月后拴测,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡府蛇,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年集索,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片汇跨。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡务荆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出穷遂,到底是詐尸還是另有隱情函匕,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布蚪黑,位于F島的核電站盅惜,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏忌穿。R本人自食惡果不足惜抒寂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望掠剑。 院中可真熱鬧蓬推,春花似錦、人聲如沸澡腾。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至毅糟,卻和暖如春红选,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背姆另。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工喇肋, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人迹辐。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓蝶防,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親明吩。 傳聞我的和親對(duì)象是個(gè)殘疾皇子间学,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

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