利用Chrome的後台網絡,分析了通過JQuery的$.ajax()把 json 數據 post 給 PHP時的幾種情況:
無法在PHP中通過$_POST 以及 $_REQUEST 獲取json數據,即
$json = $_POST['json']; // empty($json) 為1
注:PHP 默認只識別 application/x-www.form-urlencoded 標准的數據類型,因此,對型如 text/xml 或者 soap 或者 application/octet-stream 之類的內容無法解析,如果用 $_POST 數組來接收就會失敗。
js裡沒有加入屬性contentType: "application/json; charset=utf-8",
var submit_sync = function() { $.ajax({ type: "post", url: 'add-post-json.php', async: false, // 使用同步方式 // 1 需要使用JSON.stringify 否則格式為 a=2&b=3&now=14... // 2 需要強制類型轉換,否則格式為 {"a":"2","b":"3"} data: JSON.stringify({ a: parseInt($('input[name="a"]').val()), b: parseInt($('input[name="b"]').val()), now: new Date().getTime() // 注意不要在此行增加逗號 }), dataType: "json", success: function(data) { $('#result').text(data.result); } // 注意不要在此行增加逗號 }); }
$json = $GLOBALS['HTTP_RAW_POST_DATA']; // empty($json) 為 1
$json = file_get_contents("php://input"); // empty($json) 為 0
js裡加入屬性contentType: "application/json; charset=utf-8",
var submit_sync = function() { $.ajax({ type: "post", url: 'add-post-json.php', async: false, // 使用同步方式 // 1 需要使用JSON.stringify 否則格式為 a=2&b=3&now=14... // 2 需要強制類型轉換,否則格式為 {"a":"2","b":"3"} 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",dataType: "json", success: function(data) { $('#result').text(data.result); } // 注意不要在此行增加逗號 }); }
$json = $GLOBALS['HTTP_RAW_POST_DATA']; // empty($json) 為 0
$json = file_get_contents("php://input"); // empty($json) 為 0注:php://input 允許讀取 POST 的原始數據。和 $HTTP_RAW_POST_DATA 比起來,它給內存帶來的壓力較小,並且不需要任何特殊的 php.ini 設置。php://input 不能用於 enctype="multipart/form-data"。
是否加入以下
header('Content-Type:application/json;charset=utf-8');對情況A與情況B的結果沒有任何影響。
從5.2版本開始,PHP原生提供json_encode()和json_decode()函數,前者用於編碼,後者用於解碼。下面這篇博客寫的很詳細,mark!