關於JSON與JSONP簡單總結


參考資料:稍后整理

JSONP

定義:是一種跨域數據訪問方式。

作用與原理:在客戶端聲明 callback回調函數之后,客戶端通過script標簽向服務器跨域請求數據,然后服務端返回相應的JSON數據並動態執行回調函數。

 

在jQuery中使用如下:

 

JQuery Code
1     //JQuery JSONP Support  
2     var url = "http://192.168.0.103:12075/api/test.aspx?id=1&callback=?";  
3     jQuery.getJSON(url, function(data){  
4 // 處理返回的json 數據
5     alert("name:" + data.name+ ", Price:" + data.price);  
6     }); 

 

調用 webservices 使用如下:

 

View Code
1      $.getJSON(  
2      "http://192.168.0.103:12050/services/WebService1.asmx/ws/test?callback=?",  
3      { name: "jim", time: "2pm" },  
4      function(data) {
5  //處理返回的json 數據
6   alert(decodeURI(data.msg));
7  
8   });

 

服務器端(webservices 后台代碼):

webservices Code
 1 [WebMethod]  
 2 public void ws(string name,string time) {  
 3 
 4 HttpRequest Request = HttpContext.Current.Request;  
 5 string callback = Request["callback"];  
 6 
 7 HttpResponse Response = HttpContext.Current.Response;  
 8 Response.Write(callback + "({msg:' 返回數據'})");  
 9 
10 Response.End();  
11 }

 

總結JSONP:

兩點需注意:

1.不提供錯誤處理機制,有數據返回,沒有不顯示內容,獲得一個404的錯誤

2.如果使用了不信任的服務會造成很大的安全隱患。

 
        

 

JSON

 與XML相比,JSON是一個輕量級的數據交換格式。易於人閱讀和編寫。同時也易於機器解析和生成,分兩種:對象(使用下面點語法獲取屬性值)和數組(遍歷數組,索引獲取)。

1.把 JSON 文本轉換為 JavaScript 對象

從 web 服務器上讀取 JSON 數據,將 JSON 數據轉換為 JavaScript 對象,然后在網頁中使用該數據.

JavaScript 函數 eval() 可用於將 JSON 文本轉換為 JavaScript 對象。必須把文本包圍在括號中,這樣才能避免語法錯誤。

即:通過eval函數將json串轉換為json對象,然后可以通過兩種方法訪問:

服務器端:
// user 實體對象,后台序列化成對象,供前台使用
string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(user);
context.Response.Write(strJson);


前台:
$.getJSON(   
"webdata/test.aspx",
    
function(data) {
//獲取對象里面的一個值(username:用戶姓名)
       $(
"#divmessage").text(data.username);
    }
);

 2. 數組 獲取

packJson = [

{"name":"nikita", "password":"1111"},

{"name":"tony", "password":"2222"}

];

循環遍歷:

for(var i = 0; i < packJson.length; i++){

   alert(packJson[i].name + " " + packJson[i].password);

}

tks:

json 與jsonp:http://developer.51cto.com/art/201105/264791.htm

http://www.cnblogs.com/jams742003/archive/2009/12/29/1634764.html

http://www.cnblogs.com/zhangliang0115/archive/2012/08/16/2642138.html

后記:

平時用的比較多的JSON處理方法總結了一下,權當加深記憶(20130409)

http://www.cnblogs.com/victoria/archive/2013/04/09/3009517.html

后記:總結比較好的文章(20130724)

http://www.cnblogs.com/dowinning/archive/2012/04/19/2458624.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM