8

我可以发送如下请求吗?使用 JSON 样式对象分配参数。我只得到错误。但是当我使用 REST 客户端并选择 RAW 数据时,就可以了。我想我一定写错了代码。如何在 JavaScript 中发送原始 JSON 数据?有人可以帮我吗?

xmlhttp = new XMLHttpRequest();
var url = "https://someURL";
xmlhttp.open("POST", url, true);
xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
xmlhttp.onreadystatechange = function () { //Call a function when the state changes.
    if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
        alert(xmlhttp.responseText);
    }
}
var parameters = {
    "username": "myname",
    "password": "mypass"
};
// Neither was accepted when I set with parameters="username=myname"+"&password=mypass" as the server may not accept that
xmlhttp.send(parameters);
4

2 回答 2

21

不。该send()方法可以采用许多不同的参数类型,但普通对象不是其中之一(因此它可能最终会toString()被调用并变成"[Object object]")。

如果要发送 JSON,则必须:

  1. 假设您要发送 JSON:xmlhttp.setRequestHeader("Content-type", "application/json");
  2. 将您的 JavaScript 对象转换为 JSON 文本字符串:var parameters = JSON.stringify({"username":"myname","password":"mypass"});
  3. 准备好在服务器端接受 JSON 而不是 application/x-www-form-urlencoded 数据。

另请注意,由于您使用的是绝对URI,因此您可能会遇到跨域问题

于 2013-09-23T15:19:56.827 回答
2
xmlhttp = new XMLHttpRequest();
xmlhttp.open("POST", AjaxURL, true);
xmlhttp.onreadystatechange = function () { //Call a function when the state changes.
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
cb(xmlhttp.responseText);               
}
};
xmlhttp.send(JSON.stringify(Idata)); 
于 2016-06-20T05:39:59.447 回答