Javascript: отправить объект JSON с помощью Ajax? - PullRequest
136 голосов
/ 21 июня 2011

Возможно ли это?

xmlHttp.send({
    "test" : "1",
    "test2" : "2",
});

Может быть с: заголовком с content type: application/json?:

xmlHttp.setRequestHeader('Content-Type', 'application/json')

В противном случае я могу использовать:

xmlHttp.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded')

и затем JSON.stringify объект JSON и отправка его в параметре, но было бы здорово отправить его таким образом, если это возможно.

Ответы [ 3 ]

300 голосов
/ 21 июня 2011

С jQuery:

$.post("test.php", { json_string:JSON.stringify({name:"John", time:"2pm"}) });

Без jQuery:

var xmlhttp = new XMLHttpRequest();   // new HttpRequest instance 
xmlhttp.open("POST", "/json-handler");
xmlhttp.setRequestHeader("Content-Type", "application/json");
xmlhttp.send(JSON.stringify({name:"John Rambo", time:"2pm"}));
34 голосов
/ 18 ноября 2015

Если вы не используете jQuery, убедитесь, что:

var json_upload = "json_name=" + JSON.stringify({name:"John Rambo", time:"2pm"});
var xmlhttp = new XMLHttpRequest();   // new HttpRequest instance 
xmlhttp.open("POST", "/file.php");
xmlhttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xmlhttp.send(json_upload);

А для получения PHP:

 $_POST['json_name'] 
0 голосов
/ 10 августа 2018

Добавление Json.stringfy вокруг json, которое решило проблему

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...