/ / Cordova / phonegap i node.js: XMLHttpRequest zwraca status 0 - node.js, cordova, xmlhttprequest

Cordova / phonegap i node.js: XMLHttpRequest zwraca status 0 - node.js, cordova, xmlhttprequest

Napisałem serwer HTTP w node.js

var http = require("http");
http.createServer(function (request, response) {
response.writeHead(200, {"Content-Type": "text/plain"});
response.end("Hello World " + request.url + "nn");
console.log(request.url);
}).listen(8124);
console.log("Server running at http://127.0.0.1:8124/");

To powinno obsługiwać żądania z aplikacji phonegap / cordova:

function testnodejs() {
xmlHttp=GetXmlHttpObject()
if (xmlHttp==null)  {
alert ("Your webbrowser does not support HTTP Request");
return;
}
var url="http://domain.com:8124/i.t?hi=hi!";
console.log(url);
document.getElementById("maindiv").innerHTML = "<div id="itembrd" onClick="testnodejs();"><div id="item">Nodetest</div></div>";
xmlHttp.open("GET", url, true)
xmlHttp.onreadystatechange=function() {
document.getElementById("maindiv").innerHTML += xmlHttp.status + " ";
if (xmlHttp.readyState==4) {
console.log(xmlHttp.responseText);
document.getElementById("maindiv").innerHTML += xmlHttp.responseText + "<br />n";
}
}
xmlHttp.send(null)
}

W config.xml mam

<access origin=".*" />

Żądanie zwraca stan gotowości 4, ale również status 0, gdy spodziewałeś się 200. Czy ktoś ma jakąś wskazówkę?

Odpowiedzi:

3 dla odpowiedzi № 1

Odkładam to na kilka dni. Wróciłem ze świeżym porzuceniem i naprawiłem. Problem występował po stronie serwera node.js, która nie zwraca 200, ale 0. To dlatego, że zezwala na pochodzenie. Przepisałem nagłówek odpowiedzi w ten sposób:

response.writeHead(200, {
"Content-Type": "text/plain",
"Access-Control-Allow-Origin" : "*"
});

i voila! tango!

Teraz mam bardzo lekkie rozwiązanie dla żądań XHR z aplikacji Cordova / Phonegap.