欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

JSONP怎么解決Ajax跨域訪問問題

這篇文章主要介紹“JSONP怎么解決Ajax跨域訪問問題”,在日常操作中,相信很多人在JSONP怎么解決Ajax跨域訪問問題問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”JSONP怎么解決Ajax跨域訪問問題”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!

為新?lián)岬鹊貐^(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及新?lián)峋W(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、新?lián)峋W(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

JSONP是如何工作的呢,我們知道,由于同源策略的限制,XmlHttpRequest只允許請(qǐng)求當(dāng)前源(域名、協(xié)議、端口)的資源。若要跨域請(qǐng)求出于安全性考慮是不行的,但是我們發(fā)現(xiàn),Web頁面上調(diào)用js文件時(shí)則不受是否跨域的影響,而且擁有”src”這個(gè)屬性的標(biāo)簽都擁有跨域的能力,比如<script>、<img>、<iframe>,這時(shí)候,聰明的程序猿就想到了變通的方法,如果要進(jìn)行跨域請(qǐng)求, 通過使用html的script標(biāo)記來進(jìn)行跨域請(qǐng)求,并在響應(yīng)中返回要執(zhí)行的script代碼,其中可以直接使用JSON傳遞 javascript對(duì)象。即在跨域的服務(wù)端生成JSON數(shù)據(jù),然后包裝成script腳本回傳,這不就突破同源策略的限制,解決了跨域訪問的問題了么。

下面我們就看下怎么實(shí)現(xiàn):

前端代碼:

function CallWebServiceByJsonp() {
$("#SubEquipmentDetails").html('');
$.ajax({
type: "GET",
cache: false,
url: "http://servername/webservice/webservice.asmx/GetSingleInfo",
data: { strCparent: $("#Equipment_ID").val() },
dataType: "jsonp",
//jsonp: "callback",
jsonpCallback: "OnGetMemberSuccessByjsonp"
});
}
function OnGetMemberSuccessByjsonp(data) {
//處理data
alert(data);
}

后端的WebService代碼:

[WebMethod]
[ScriptMethod(ResponseFormat = ResponseFormat.Json, UseHttpGet = true)]
public void GetSingleInfo(string strCparent)
{
string ret = string.Empty;
HttpContext.Current.Response.ContentType = "application/json;charset=utf-8";
string jsonCallBackFunName = HttpContext.Current.Request.Params["callback"].ToString();
//string jsonCallBackFunName1 = HttpContext.Current.Request.QueryString["callback"].Trim();
//上面代碼必須
//中間代碼執(zhí)行自己的業(yè)務(wù)操作,可返回自己的任意信息(多數(shù)據(jù)類型)
BLL.equipment eq_bll = new BLL.equipment();
List<Model.equipment> equipmentList = new List<Model.equipment>();
equipmentList = eq_bll.GetModelEquimentList(strCparent);
ret = JsonConvert.SerializeObject(equipmentList);
//下面代碼必須
HttpContext.Current.Response.Write(string.Format("{0}({1})", jsonCallBackFunName, ret));
HttpContext.Current.Response.End();
}

如上所示,前端的CallWebServiceByJsonp方法采用jQuery的ajax方法調(diào)用后端的Web服務(wù)GetSingleInfo方法,后臺(tái)的GetSingleInfo方法,使用前端的回調(diào)方法OnGetMemberSuccessByjsonp包裝后臺(tái)的業(yè)務(wù)操作的JSON對(duì)象,返回給前端一段javascript片段執(zhí)行。巧妙的解決了跨域訪問問題。

JSONP的缺點(diǎn):

JSONP不提供錯(cuò)誤處理。如果動(dòng)態(tài)插入的代碼正常運(yùn)行,你可以得到返回,但是如果失敗了,那么什么都不會(huì)發(fā)生。

到此,關(guān)于“JSONP怎么解決Ajax跨域訪問問題”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

網(wǎng)站標(biāo)題:JSONP怎么解決Ajax跨域訪問問題
標(biāo)題鏈接:http://aaarwkj.com/article14/iiggge.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站微信小程序、虛擬主機(jī)App開發(fā)、網(wǎng)站導(dǎo)航、網(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í)需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
中文字幕国产成人在线视频| 91极品气质女神长腿翘臀| 日韩亚洲中文一区三级黄片| 日韩亚洲天堂视频免费观看| 欧美日韩国产精品高清| 国产乱av一区二区三区| 人妻少妇精品视频二区| 99热这里有精品久久| 天天操夜夜操夜夜操精品| 在线国产视频一区二区三区| 亚洲一区二区三区色婷婷| 黑寡妇精品欧美一区二区毛| 亚洲中国av一区二区| 成人黄色av免费看| 日韩激情av中文字幕| 中文字幕成人在线电影 | 欧美精品黑人三级精品| 内射极品美女在线观看| 欧美特黄大片在线观看| 免费成人激情在线电影| 欧美内射专区精品一区| 亚洲视频一区视频二区| 日本一区二区日本一区| 国产日韩精品激情另类综合| 麻豆精品情欲人妻二区| 国产99热这里只有精品| 亚洲综合欧美日韩一区| 欧美一区二区三区亚洲| 日本黄色录像在线观看| 99热这里只有精品56| 麻豆片免费观看在线看| 日本2区3区视频在线观看| 国产一级二级三级在线电影| 亚洲国产成人精品女人| 日本久久在线观看视频| 日本高清精品视频免费| 久久 久久国内精品亚洲| 日韩国产亚洲欧美国产| 日韩欧美人妻中文字幕| 黄色资源网日韩三级一区二区| 久章草在线免费视频播放|