通過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 數組來接收就會失敗。
情況A:
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);
} // 注意不要在此行增加逗號
});
}
- 使用 $GLOBALS['HTTP_RAW_POST_DATA'] 后無法獲取到數據,即
- $json = $GLOBALS['HTTP_RAW_POST_DATA']; // empty($json) 為 1
-
- 使用file_get_contents("php://input"); 可以獲取數據,即
-
$json = file_get_contents("php://input"); // empty($json) 為 0 -
情況B:
- 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); } // 注意不要在此行增加逗號 }); } -
- 使用 $GLOBALS['HTTP_RAW_POST_DATA'] 后可以獲取到數據,即
-
$json = $GLOBALS['HTTP_RAW_POST_DATA']; // empty($json) 為 0
-
- 使用file_get_contents("php://input"); 可以獲取數據,即
-
$json = file_get_contents("php://input"); // empty($json) 為 0 - 注:php://input 允許讀取 POST 的原始數據。和 $HTTP_RAW_POST_DATA 比起來,它給內存帶來的壓力較小,並且不需要任何特殊的 php.ini 設置。php://input 不能用於 enctype="multipart/form-data"。
