溫馨提示×

溫馨提示×

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

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

jQuery+JSONP跨域請求怎么實現(xiàn)

發(fā)布時間:2021-06-15 14:14:33 來源:億速云 閱讀:216 作者:小新 欄目:web開發(fā)

這篇文章主要介紹jQuery+JSONP跨域請求怎么實現(xiàn),文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

  JSONP(JSON with Padding)是JSON的一種“使用模式”,可用于解決主流瀏覽器的跨域數(shù)據(jù)訪問的問題。由于同源策略,一般來說位于 server1.example.com 的網(wǎng)頁無法與不是 server1.example.com的服務(wù)器溝通,而 HTML 的<script> 元素是一個例外。利用 <script> 元素的這個開放策略,網(wǎng)頁可以得到從其他來源動態(tài)產(chǎn)生的 JSON 資料,而這種使用模式就是所謂的 JSONP。用 JSONP 抓到的資料并不是 JSON,而是任意的JavaScript,用 JavaScript 直譯器執(zhí)行而不是用 JSON 解析器解析。

??上面一段話來自百度百科,概念永遠是那么抽象難懂,看例子才是最直觀的表現(xiàn)。例子看的多了,領(lǐng)悟到那個點了,自然自己也會學著抽象的描述了。這就是為什么常說“學習知識是從薄到厚,又由厚到薄的過程”。好了扯遠了。下面直接來看一個例子。

 jQuery+JSONP跨域請求怎么實現(xiàn)

??問題:本地現(xiàn)有一個頁面demo.html需要從http://localhost:3561/User/GetAllNames獲取數(shù)據(jù)并展示。

??解答:由于問題中的兩方不在同一服務(wù)器,故需要使用jsonp來跨域訪問。

??① 客戶端編寫

??客戶端使用jQuery中提供的$.getJson方法來跨域訪問。getJson有3個參數(shù):

????I.   url:請求地址;

????II.  data:發(fā)送到服務(wù)端的參數(shù);

????III. callback:成功時的回調(diào)函數(shù)。

??getJson的使用方法和普通的$.get方法基本一致,不同的地方在于getJson需要在url后面的參數(shù)部分加上callback=?這一固定部分,jQuery 將自動替換 ? 為正確的函數(shù)名,以執(zhí)行回調(diào)函數(shù)。然后在回調(diào)函數(shù)中操作從異域返回的json對象,回調(diào)函數(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>

  ② 服務(wù)端編寫

??服務(wù)端的邏輯主要是將數(shù)據(jù)序列化為json字符串,然后封裝成"callback(json)"的形式,callback為jQuery自動生成并傳到服務(wù)端的函數(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);
  }
}

  至此,便成功解決了問題。

jQuery+JSONP跨域請求怎么實現(xiàn)

?思考:如果服務(wù)端已經(jīng)寫死了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+JSONP跨域請求怎么實現(xiàn)”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

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

AI