輕松搞定jQuery+JSONP跨域請求的解決方案
JSONP(JSON with Padding)是JSON的一種“使用模式”,可用于解決主流瀏覽器的跨域數(shù)據(jù)訪問的問題。由于同源策略,一般來說位于 server1.example.com 的網頁無法與不是 server1.example.com的服務器溝通,而 HTML 的<script> 元素是一個例外。利用 <script> 元素的這個開放策略,網頁可以得到從其他來源動態(tài)產生的 JSON 資料,而這種使用模式就是所謂的 JSONP。用 JSONP 抓到的資料并不是 JSON,而是任意的JavaScript,用 JavaScript 直譯器執(zhí)行而不是用 JSON 解析器解析。
上面一段話來自百度百科,概念永遠是那么抽象難懂,看例子才是最直觀的表現(xiàn)。例子看的多了,領悟到那個點了,自然自己也會學著抽象的描述了。這就是為什么常說“學習知識是從薄到厚,又由厚到薄的過程”。好了扯遠了。下面直接來看一個例子。
問題:本地現(xiàn)有一個頁面demo.html需要從http://localhost:3561/User/GetAllNames獲取數(shù)據(jù)并展示。
解答:由于問題中的兩方不在同一服務器,故需要使用jsonp來跨域訪問。
① 客戶端編寫
客戶端使用jQuery中提供的$.getJson方法來跨域訪問。getJson有3個參數(shù):
I. url:請求地址;
II. data:發(fā)送到服務端的參數(shù);
III. callback:成功時的回調函數(shù)。
getJson的使用方法和普通的$.get方法基本一致,不同的地方在于getJson需要在url后面的參數(shù)部分加上callback=?這一固定部分,jQuery 將自動替換 ? 為正確的函數(shù)名,以執(zhí)行回調函數(shù)。然后在回調函數(shù)中操作從異域返回的json對象,回調函數(shù)callback的參數(shù)即為該json對象。
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <title></title> </head> <body> <ul id="nameList"></ul> <script src="http://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script> <script type="text/javascript"> $.getJSON("http://localhost:3561/User/GetAllNames?callback=?", function(json) { for (var i = 0; i < json.length; i++) { $("#nameList").append("<li>" + json[i] + "</li>"); } }); </script> </body> </html>
服務端的邏輯主要是將數(shù)據(jù)序列化為json字符串,然后封裝成"callback(json)"的形式,callback為jQuery自動生成并傳到服務端的函數(shù)名稱。下面使用C#實現(xiàn):
public class UserController : Controller { public string GetAllNames(string callback) { string[] names = new string[] { "張三豐", "張無忌", "令狐沖", "楊過", "郭靖" }; JavaScriptSerializer jss = new JavaScriptSerializer(); string json = jss.Serialize(names); return string.Format("{0}({1})", callback, json); } }
思考:如果服務端已經寫死了callback(如:return string.Format("moty({0})", json);),那么客戶端該怎么寫呢?
參考:
$.ajax("http://localhost:3561/User/GetAllNames", { jsonpCallback: "moty", dataType: "jsonp", success: function(json) { for (var i = 0; i < json.length; i++) { $("#nameList").append("<li>" + json[i] + "</li>"); } } });
相關文章
Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用法總結
本文是對Jquery中$.get(),$.post(),$.ajax(),$.getJSON()的用進行了詳細的總結介紹,需要的朋友可以過來參考下,希望對大家有所幫助2013-11-11jquery validate和jquery form 插件組合實現(xiàn)驗證表單后AJAX提交
在ajax流行的時代,好像很少能看見傳統(tǒng)的同步提交表單方式了,是啊我們當然要用更加給力的AJAX來實現(xiàn)異步無刷新提交表單,好了開始今天的jQuery之旅吧,今天我們來利用jquery.validate和jquery.form 插件組合實現(xiàn)驗證表單后AJAX提交 ,需要的朋友可以參考下2015-08-08