如何解決Ajax請(qǐng)求跨域問(wèn)題

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)如何解決Ajax請(qǐng)求跨域問(wèn)題,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

創(chuàng)新互聯(lián)主營(yíng)宜春網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,成都App定制開(kāi)發(fā),宜春h5小程序開(kāi)發(fā)搭建,宜春網(wǎng)站營(yíng)銷推廣歡迎宜春等地區(qū)企業(yè)咨詢

一、解決方案:

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

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

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

session是服務(wù)器的一個(gè)內(nèi)存空間,當(dāng)一個(gè)客戶端訪問(wèn)服務(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頁(yè)面上調(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)求處理程序或頁(yè)面的,用以獲得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ù)器代碼:
//先取得傳過(guò)來(lái)的回調(diào)函數(shù)名
var cb=request.callback;
//要傳送給客戶端的 json數(shù)據(jù)
var jsonobj=xxx
res.send("("+jsonobj+");");
//即生成類似于 handle(jsonobj); 后發(fā)送給客戶端

上述就是小編為大家分享的如何解決Ajax請(qǐng)求跨域問(wèn)題了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

分享文章:如何解決Ajax請(qǐng)求跨域問(wèn)題
網(wǎng)頁(yè)URL:http://muchs.cn/article26/ghspcg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開(kāi)發(fā)App設(shè)計(jì)、網(wǎng)站維護(hù)、網(wǎng)站設(shè)計(jì)、ChatGPT靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司