Drupal JSON POST из PhoneGap
Вопрос
Я пытаюсь отправить запрос POST в модуль Drupal Services и модуль JSON_Server, однако получаю
{ "#ошибка":правда, "#данные":«Неверный метод» }
Поскольку PhoneGap запускает html-файлы локально на телефоне, стоит ли мне беспокоиться о JSONP.Проблема, с которой я столкнулся, заключается в том, что мне нужно отправлять данные POST, а JSONP допускает только GET.Любые идеи будут полезны.Спасибо!
//SEND REQUEST AND CALLBACK FUNCTION var req; DrupalService.prototype.request = function(dataObject, callback){ req = false; var url = DRUPAL_JSON_URL; var params = "data="+dataObject; try { req = new XMLHttpRequest(); } catch(e) { req = false; } if(req) { req.onreadystatechange = function() {//Call a function when the state changes. if(req.readyState == 4 && req.status == 200) { console.log(">> "+req.responseText); } } req.open("POST", url, false); req.send(params); } }
Решение
Итак, я понял: это связано с конфликтующими типами контента.
убедитесь, что вы установили его как
Content-Type = application/x-www-form-urlencoded;
var DRUPAL_JSON_URL = "http://myDrupalsSite.com/services/json";
var req;
DrupalService.prototype.request = function(dataObject, callback){
var url = DRUPAL_JSON_URL;
req = false;
var params = "method=system.connect";
try {
req = new XMLHttpRequest();
} catch(e) {
req = false;
}
if(req) {
req.onreadystatechange = function() {//Call a function when the state changes.
if(req.readyState == 4 && req.status == 200) {
alert("test " + req.responseText)
console.log("RESPONSE "+req.responseText);
}
}
req.open("POST", url, true);
req.setRequestHeader("Content-length", params.length);
req.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
req.send(params);
}
}
Не связан с StackOverflow