色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

Ajax請(qǐng)求跨域問題解決方案分析

瀏覽:176日期:2022-06-11 10:19:24

本文實(shí)例講述了Ajax請(qǐng)求跨域問題解決方案。分享給大家供大家參考,具體如下:

幾乎每種瀏覽器都存在默認(rèn)的安全機(jī)制,都有同源策略,因?yàn)闉g覽器惡意的把每個(gè)外部請(qǐng)求的都當(dāng)做是黑客攻擊,相當(dāng)于是對(duì)自身的保護(hù),所以瀏覽器在運(yùn)行腳本時(shí)會(huì)判斷腳本與請(qǐng)求的頁面是否是同一來源,這個(gè)同一來源,包括1、協(xié)議,2、地址,3、端口,只有三者都相同才被認(rèn)為是同一來源。

一、解決方案:

1,在服務(wù)器端的響應(yīng)頭中添加一個(gè)http參數(shù):

res.setHeader("Access-Control-Allow-Origin", "*");
res.setHeader("Access-Control-Allow-Methods", "PUT,GET,POST,DELETE,OPTIONS");

用于告訴客戶端可以訪問這個(gè)跨域的資源,但是問題又來了,知道HTTP協(xié)議的同學(xué)都清楚,http是一種無狀態(tài)的基于請(qǐng)求響應(yīng)的協(xié)議,每次的請(qǐng)求都是全新的,服務(wù)器無法保持狀態(tài),這時(shí)我們可以利用服務(wù)器的session機(jī)制:

session是服務(wù)器的一個(gè)內(nèi)存空間,當(dāng)一個(gè)客戶端訪問服務(wù)器時(shí),服務(wù)器會(huì)為這個(gè)客戶端創(chuàng)建一個(gè)唯一的空間,并且給定一個(gè)編號(hào),這個(gè)編號(hào)就是sessionid。

在響應(yīng)客戶端時(shí),在響應(yīng)頭中加入了cookie.sessionid=xxxx,將這個(gè)cookie響應(yīng)給客戶端,當(dāng)這個(gè)客戶端下一次請(qǐng)求服務(wù)器時(shí),客戶端會(huì)自動(dòng)將cookie寫到請(qǐng)求頭中發(fā)送給給服務(wù)器,服務(wù)器接受到這個(gè)請(qǐng)求之后,從請(qǐng)求頭中取出這個(gè)sessionid,這樣就可以判斷是哪一個(gè)用戶了。

二、解決方案:JSONP

原理:Web頁面上調(diào)用js文件時(shí)則不受是否跨域的影響(不僅如此,凡是擁有”src”這個(gè)屬性的標(biāo)簽都擁有跨域的能力,比如<script>、<img>、<iframe>);所以,我們可以這樣做,在客戶端聲明一個(gè)處理json的函數(shù),這個(gè)函數(shù)作為參數(shù)傳給服務(wù)器,由服務(wù)器調(diào)用(服務(wù)器生成動(dòng)態(tài)的調(diào)用代碼,并且把想要傳給客戶端的json數(shù)據(jù)作為實(shí)參注入)

jQuery已經(jīng)為我們做好了一切,我們只需調(diào)用即可

例如:

客戶端代碼:

$.ajax({
  type: "GET",
  url: "服務(wù)器處理地址",
  dataType:"jsonp",
  jsonp: "callback",
  //傳遞給請(qǐng)求處理程序或頁面的,用以獲得jsonp回調(diào)函數(shù)名的參數(shù)名(一般默認(rèn)為:callback)
  //自定義的jsonp回調(diào)函數(shù)名稱,默認(rèn)為jQuery自動(dòng)生成的隨機(jī)函數(shù)名,也可以寫"?",jQuery會(huì)自動(dòng)為你處理數(shù)據(jù)
  success: function( data){
    alert( "helloworl "+ data.count );
  } ,
  error: function(msg){
    alert( msg);
  }
});
//回調(diào)函數(shù),由服務(wù)器端調(diào)用的函數(shù)
function handle( jsonResult ){
  //處理
}
服務(wù)器代碼:
//先取得傳過來的回調(diào)函數(shù)名
var cb=request.callback;
//要傳送給客戶端的 json數(shù)據(jù)
var jsonobj=xxx
res.send("("+jsonobj+");");
//即生成類似于 handle(jsonobj); 后發(fā)送給客戶端

更多關(guān)于ajax相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jquery中Ajax用法總結(jié)》、《JavaScript中ajax操作技巧總結(jié)》、《PHP+ajax技巧與應(yīng)用小結(jié)》及《asp.net ajax技巧總結(jié)專題》

希望本文所述對(duì)大家ajax程序設(shè)計(jì)有所幫助。

標(biāo)簽: Ajax
相關(guān)文章:
主站蜘蛛池模板: 台湾三级香港三级在线中文 | a级男女性高爱潮高清试 | 国产 一二三四五六 | 91无套极品外围在线播放 | 亚洲第一页在线播放 | 亚洲欧美日韩久久精品第一区 | 亚欧成人中文字幕一区 | 国产呦系列呦 | 欧美一级毛片免费播放aa | 日本一级毛片视频无遮挡免费 | 亚洲国产精品久久网午夜 | 欧美成人欧美激情欧美风情 | 亚洲视频精品 | 综合欧美视频一区二区三区 | 国产亚洲精品线观看77 | 欧美午夜视频 | 女人成午夜大片7777在线 | 91福利精品老师国产自产在线 | 精品久久久久久无码中文字幕 | 免费aⅴ片| 国产成人欧美视频在线 | 99视频精品全部 在线 | 一级国产精品一级国产精品片 | 国内国产真实露脸对白 | 国产大片中文字幕在线观看 | 国产成人精品高清不卡在线 | 中文字幕欧美在线观看 | 成年人在线观看视频网站 | 久久精品国产6699国产精 | 中文字幕在线观看一区二区三区 | 免费又黄又爽又猛大片午夜 | 台湾精品视频在线观看 | 欧美成一级 | 黄到让你下面湿的视频 | 亚洲狠狠狠一区二区三区 | 全部免费国产潢色一级 | 深夜国产成人福利在线观看女同 | 好看的看黄a大片爽爽影院 好男人天堂网 | 亚洲第一毛片 | 美女操穴视频 | 欧美极品在线视频 |