admin管理员组文章数量:1344240
Is there anything special I have to do to a JSON object before I send it with AJAX? My code looks like this:
runAjax(JSON.stringify(data));
}
function runAjax(JSONstring)
{
ajax = getHTTPObject();
var params = "?data=" + JSONstring;
ajax.open("POST", "createtrip.php", true);
ajax.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
ajax.setRequestHeader("Content-length", params.length);
ajax.setRequestHeader("Connection", "close");
ajax.onreadystatechange = serverSpeaks;
ajax.send(params);
}
Right now the server is not receiving the data. I get null on the server side but the client side JSONString is set. Is there something I'm doing wrong?
Is there anything special I have to do to a JSON object before I send it with AJAX? My code looks like this:
runAjax(JSON.stringify(data));
}
function runAjax(JSONstring)
{
ajax = getHTTPObject();
var params = "?data=" + JSONstring;
ajax.open("POST", "createtrip.php", true);
ajax.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
ajax.setRequestHeader("Content-length", params.length);
ajax.setRequestHeader("Connection", "close");
ajax.onreadystatechange = serverSpeaks;
ajax.send(params);
}
Right now the server is not receiving the data. I get null on the server side but the client side JSONString is set. Is there something I'm doing wrong?
Share Improve this question asked Aug 27, 2009 at 17:00 DanDan 8171 gold badge8 silver badges15 bronze badges 1- you can check with Firebug if you have an error or call to server – Eldar Djafarov Commented Aug 27, 2009 at 17:12
3 Answers
Reset to default 6You are sending data over POST, you don't need the '?'
character at the beginning of the params
variable, also I remend you to encode the JSONString to avoid problems.
Note that you are missing the var
statement for the ajax
variable, this is declaring it globally (window.ajax) and I think that you don't need it globally...
function runAjax(JSONstring) {
var params = "data=" + encodeURIComponent(JSONstring),
ajax = getHTTPObject();
ajax.open("POST", "createtrip.php", true);
ajax.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
ajax.setRequestHeader("Content-length", params.length);
ajax.setRequestHeader("Connection", "close");
ajax.onreadystatechange = serverSpeaks;
ajax.send(params);
}
You should pass through an encoder to send the data correctly. Of course you would first have to see that the variable "data" is well formed as "JSON".
lib to encode/decode
other link encode/decode
The server can deal with post body like name1=value&name2=value2.
If you are using PHP, you can receive the json string by:
$data = file_get_contents("php://input");
本文标签: javascriptSend JSON with AJAXStack Overflow
版权声明:本文标题:javascript - Send JSON with AJAX - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743729369a2528919.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论