Reputation: 464
I have a phonegap android application which is attempting to get data from an external server:
The server is a .net WebAPI - and uses the communcation is via JSONP. The same code/server works in iOS with phonegap 2.7. For Android I am using phonegap 3.1. I have double checked the URL to make sure it's correct. I have also got the following line in my config.xml file.
<access origin="*" subdomains="true" />
The request details are here:
Request URL:http://XXXXXXXXXXXX.com/server/api/messagetypeopt/1?callback=jQuery17209047717128414661_1386902222072&_=1386902252817
Request Method:GET
Status Code:404 Not Found (from cache)
Request Headersview source
Accept:*/*
User-Agent:Mozilla/5.0 (Linux; Android 4.4; sdk Build/KRT16L) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/30.0.0.0 Mobile Safari/537.36
Query String Parametersview sourceview URL encoded
callback:jQuery17209047717128414661_1386902222072
_:1386902252817
and the javascript request code is
$.support.cors = true;
$.mobile.allowCrossDomainPages = true;
$.mobile.loading('show');
// enableFrontPageButtons(1)
enableButtons(0);
console.log('about to get message types');
try {
$.ajax({
//url: 'http://localhost:8956/api/messagetypeopt/' + SENDER_ID ,
url: SERVER + '/api/messagetypeopt/' + SENDER_ID ,
type: 'GET',
dataType: 'jsonp',
jsonp: 'callback',
crossDomain: true,
async: false,
success: function (data) {
//alert('1');
localStorage.setItem("rawMessageTypes", JSON.stringify(data.branches));
Sender.updateBranchesData(data);
Sender.updateSenderData(data);
//alert('2');
setupBranches(data.branches);
setMessageTypesDB(data.branches); // store in local database.
updateMessageTypes(data.branches);
WriteMessageList( getMessageDataForBranch(JSON.parse(localStorage.getItem("rawMessageTypes"))));
//alert('3');
// save sender data and branch data
enableButtons(1);
//$('#libName').val(ConfigData.SENDER_NAME);
changeTheBranch(CURRENT_BRANCH);
// alert('4');
//alert('Update Complete');
$('messagetypepopuptext').text('Update Complete');
$('messagetypepopup').popup();
},
statusCode: {
500: function() {
alert("An incorrect request went to the server, check your UserID? ");
enableButtons(1);
$.mobile.changePage('#pageSetup', {changeHash: false});
} ,
400: function() {
alert("An incorrect request went to the server, check your UserID? ");
enableButtons(1);
$.mobile.changePage('#pageSetup', {changeHash: false});
}
},
error: function (x, y, z) {
//alert('There was an error getting data from the server');
enableButtons(0);
$.mobile.changePage('#pageSetup', {changeHash: false});
},
complete: function (a, b) {
//alert('complete:' + a + '\n' + b);
$.mobile.loading('hide');
}
});
I'm really stuck on this - so i'd really like some help. thanks :)
Upvotes: 1
Views: 781
Reputation: 337
I am in the same page as you. It works perfectly on iOS7 and even Android 2.3 virtual machine but it does not work on Android 4.0.3 I am using Phonegap 3.1
--- EDIT ---
I have various sites for whitelisting and I put them all in different ways
<access origin="*://site.com" subdomains="true"/>
<access origin="*://site.com/*" subdomains="true"/>
<access origin="*://site.com/something/*" subdomains="true"/>
<access origin="https://site.com/" subdomains="true"/>
Since I am using AngularJS I do not know how to help you in your code, but once I tested using jquery and I did not have your support CORS code. I also added the
<access origin="..." subdomains="true"/>
on the config.xml located on res/xml/config.xml.
Upvotes: 2