亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-08-18 10:11:38 來源:億速云 閱讀:123 作者:chen 欄目:web開發

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

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

下面我們就看下怎么實現:

前端代碼:

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();
//上面代碼必須
//中間代碼執行自己的業務操作,可返回自己的任意信息(多數據類型)
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方法調用后端的Web服務GetSingleInfo方法,后臺的GetSingleInfo方法,使用前端的回調方法OnGetMemberSuccessByjsonp包裝后臺的業務操作的JSON對象,返回給前端一段javascript片段執行。巧妙的解決了跨域訪問問題。

JSONP的缺點:

JSONP不提供錯誤處理。如果動態插入的代碼正常運行,你可以得到返回,但是如果失敗了,那么什么都不會發生。

到此,關于“JSONP怎么解決Ajax跨域訪問問題”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

合阳县| 县级市| 宁国市| 吕梁市| 调兵山市| 武夷山市| 天台县| 同心县| 江安县| 抚顺县| 乐东| 京山县| 柯坪县| 彭泽县| 陕西省| 沂水县| 当雄县| 和龙市| 大竹县| 杂多县| 兴国县| 会同县| 霍城县| 安义县| 连江县| 宜丰县| 武宁县| 县级市| 喜德县| 九龙县| 东方市| 永顺县| 多伦县| 泽州县| 中西区| 峡江县| 房产| 铜陵市| 桃园市| 修水县| 兴义市|