我正在尝试创建一个POST请求,遗憾的是,POST的正文似乎永远不会被发送。
以下是我正在使用的代码。当用户单击链接而不是表单“提交”按钮时,将调用代码。它运行时没有错误,调用正在调用的servlet但是,如前所述,POST的主体似乎永远不会被发送。
我可以验证请求体永远不会被发送,因为我可以访问被调用的servlet。
我尝试使用“参数”代替“requestBody”。我也尝试过使用参数字符串(x = a?y = b)。我还验证了“ckULK”确实包含有效值。
有什么想法吗?
new Ajax.Request(sURL,
{
method: 'POST'
, contentType: "text/x-json"
, requestBody: {ulk:ckULK}
, onFailure:
function(transport)
{
vJSONResp = transport.responseText;
var JSON = eval( "(" + vJSONResp + ")" );
updateStatus(JSON.code + ": " + JSON.message);
} // End onFailure
, onSuccess:
function(transport)
{
if (200 == transport.status)
{
vJSONResp = transport.responseText;
}
else
{
log.value += "\n" + transport.status;
}
} // End onSuccess
}); // End Ajax.request
答案 0 :(得分:5)
这些是Firebug和Firefox真正有用的情况。如果您没有Firebug,我建议您安装它,并检查正在发送的请求。
您还必须坚持使用parameters
代替requestBody
。
此:
new Ajax.Request(sURL,
{
method: 'POST',
parameters: 'hello=world&test=yes',
onFailure: function(transport) {
vJSONResp = transport.responseText;
var JSON = eval( "(" + vJSONResp + ")" );
updateStatus(JSON.code + ": " + JSON.message);
},
onSuccess: function(transport) {
if (200 == transport.status) {
vJSONResp = transport.responseText;
} else {
log.value += "\n" + transport.status;
}
}
});
绝对可以。
答案 1 :(得分:1)
只需将数据作为 parameters
传递给Ajax请求构造函数:
new Ajax.Request(url, {
method: 'POST',
parameters: {
hello: "world", test: "test"
},
onSuccess: function(transport){
var data = transport.responseText.evalJSON();
}
});
答案 2 :(得分:0)
当我遇到此问题时,解决方案是从contentType
选项中删除Ajax.Request
。
answer Paolo Bergantino contentType
{{3}}未在Ajax.Request
选项中定义。
由于未知原因parameters
中定义的参数未被发送(FF没有显示它们,我的服务器看到了空的POST主体)。
我的一位同事建议使用postBody
代替parameters
,但我没有尝试过。