使用Ajax方式POST JSON數據包(轉)


add by zhj: 用ajax發送json數據時注意兩點,
第一,使用JSON.stringify()函數將data轉為json格式的字符串,如下
data: JSON.stringify({
    a: parseInt($( 'input[name="a"]').val()),  
    b: parseInt($( 'input[name="b"]').val()),  
    now:  new Date().getTime() // 注意不要在此行增加逗號  

})

第二,contentType:  "application/json; charset=utf-8"
(注:$.ajax中的參數dataType相當於accept header)
0.前言
    本文解釋如何使用Jquery中的ajax方法傳遞JSON數據包,傳遞的方法使用POST(當然PUT又有時也是一個不錯的選擇)。POST JSON數據包相比標准的POST格式可讀性更好些,層次結構也更清晰。
    為了說明問題,前端和后端較為簡單,重點突出AJAX的應用。
 
    【前端】——add-post-json.html
圖1 add頁面
    【后端】——add-post-json.php
[php]  view plain  copy
 
 在CODE上查看代碼片派生到我的代碼片
  1. <?php  
  2. // 返回JSON格式  
  3. header('Content-Type:application/json;charset=utf-8');  
  4. $result = array();  
  5.   
  6. // 獲得原始輸入內容  
  7. $json = file_get_contents("php://input");  
  8. //var_dump($input_str);  
  9.   
  10. // JSON轉換為PHP對象  
  11. $obj = json_decode($json);  
  12.   
  13. $a = $obj->a; // var_dump($a);  
  14. $b = $obj->b; // var_dump($b);  
  15.   
  16. $result["result"] = $a + $b;  
  17. echo json_encode($result, JSON_NUMERIC_CHECK);  
  18. ?>  
 
    【代碼倉庫】—— test-jquery-ajax
     代碼倉庫位於bitbucket使用Hg(而不是Git),Hg在windows或ubuntu上均有很好用的GUI工具——TortoiseHg,本人愚笨沒能熟練掌握Git。
    【 TortoiseHg使用說明】——如果沒有使用過Hg請參考博文hg clone部分操作即可。   
    【 JQuery 中文API
    【相關博文】
 
1.POST JSON數據包
[javascript]  view plain  copy
 
 在CODE上查看代碼片派生到我的代碼片
  1. var submit_sync = function() {  
  2.     $.ajax({  
  3.         type: "post",  
  4.         url: 'add-post-json.php',  
  5.         async: false, // 使用同步方式  
  6.         // 1 需要使用JSON.stringify 否則格式為 a=2&b=3&now=14...  
  7.         // 2 需要強制類型轉換,否則格式為 {"a":"2","b":"3"}  
  8.         data: JSON.stringify({                    
  9.             a: parseInt($('input[name="a"]').val()),  
  10.             b: parseInt($('input[name="b"]').val()),  
  11.             now: new Date().getTime() // 注意不要在此行增加逗號  
  12.         }),  
  13.         contentType: "application/json; charset=utf-8",  
  14.         dataType: "json",  
  15.         success: function(data) {  
  16.             $('#result').text(data.result);  
  17.         } // 注意不要在此行增加逗號  
  18.     });  
  19. }  
 
【HTTP請求部分內容】
POST /test-jquery-ajax/add-post-json.php HTTP/1.1 
Host: 192.168.1.104 
Connection: keep-alive 
Content-Length: 35 
Accept: application/json, text/javascript, */*; q=0.01 
X-Requested-With: XMLHttpRequest 
Content-Type: application/json; charset=UTF-8 
 
{"a":12,"b":34,"now":1403525674676}
 
【HTTP響應部分內容】
HTTP/1.1 200 OK
Content-Length: 13
Content-Type: application/json;charset=utf-8
 
{"result":46}
 
2.重要說明
【1】
需要使用JSON.stringify,它將js的數據類型轉為json格式的字符串: '{"a":12,"b":34,"now":1403525674676}'
如果不用JSON.stringify,那POST消息體是普通的字符串: 'a=12&b=34&now=1403525674676'
以下寫法並不能達到POST JSON數據包的效果,這是標准的POST格式。
[javascript]  view plain  copy
 
 在CODE上查看代碼片派生到我的代碼片
  1. data: {                    
  2.     a: parseInt($('input[name="a"]').val()),  
  3.     b: parseInt($('input[name="b"]').val()),  
  4.     now: new Date().getTime() // 注意不要在此行增加逗號  
  5. },  
【HTTP請求部分內容】
POST /test-jquery-ajax/add-post-json.php HTTP/1.1 
Host: 192.168.1.104 
Content-Length: 27 
X-Requested-With: XMLHttpRequest 
Content-Type: application/json; charset=UTF-8 

a=12&b=34&now=1403525989275
 
【2】
需要強制類型轉換parseInt(),否則HTTP請求為 {"a":"12","b":"34"}
以下代碼並不能達到預期效果
[javascript]  view plain  copy
 
 在CODE上查看代碼片派生到我的代碼片
  1. data: JSON.stringify({                    
  2.     a: $('input[name="a"]').val(),  
  3.     b: $('input[name="b"]').val(),  
  4.     now: new Date().getTime() // 注意不要在此行增加逗號  
  5. }),  
【HTTP請求部分內容】
POST /test-jquery-ajax/add-post-json.php HTTP/1.1 
Host: 192.168.1.104 
Content-Length: 39 
X-Requested-With: XMLHttpRequest 
Content-Type: application/json; charset=UTF-8 

{"a":"12","b":"34","now":1403526427890}
 
【3】
IE8兼容,IE7和IE6不支持JSON.stringify,使用請慎重。
 


免責聲明!

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



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