首頁 >web前端 >js教程 >透過jQuery+JSONP中跨域請求的方法(詳細教程)

透過jQuery+JSONP中跨域請求的方法(詳細教程)

亚连
亚连原創
2018-06-01 10:46:101598瀏覽

了解了jsonp之後,大家應該也都明白了,jsonp主要就是用來實現跨域的獲取數據,今天我們就來詳細探討下如何在實際中應用jsonp實現跨域

  JSONP (JSON with Padding)是JSON的一種“使用模式”,可用於解決主流瀏覽器的跨域資料存取的問題。由於同源策略,一般來說位於 server1.example.com 的網頁無法與不是 server1.example.com的伺服器溝通,而 HTML 的3f1c4e4b6b16bbbd69b2ee476dc4f83a 元素是例外。利用 3f1c4e4b6b16bbbd69b2ee476dc4f83a 元素的這個開放策略,網頁可以得到從其他來源動態產生的 JSON 資料,而這個使用模式就是所謂的 JSONP。用 JSONP 抓到的資料不是 JSON,而是任意的JavaScript,用 JavaScript 直譯器執行而不是用 JSON 解析器解析。

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

 

  問題:本地現有一個頁面demo.html需要從http://localhost:3561/User/GetAllNames取得資料並展示。

  解答:由於問題中的兩方不在同一伺服器,故需要使用jsonp來跨網域存取。

  ① 客戶端編寫

  客戶端使用jQuery中提供的$.getJson方法來跨網域存取。 getJson有3個參數:

    I.   url:請求位址;

    II.  data:傳送至服務端的參數;

#   ⃀函數時的回調。 。

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

  ② 服務端編寫

  服務端的邏輯主要是將資料序列化為json字串,然後封裝成"callback(json)"的形式,callback為jQuery自動產生並傳到服務端的函數名稱。以下使用C#實作:

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>");
    }
  }
});

上面是我整理給大家的,希望今後會對大家有幫助。

相關文章:

利用ES6透過WeakMap解決記憶體洩漏問題(詳細教學)

Node.JS循環刪除非空資料夾及子目錄下的所有檔案

Javascript中prototype與__proto__的關係詳解

#

以上是透過jQuery+JSONP中跨域請求的方法(詳細教程)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn