I can't create a successful get request in Angular 1.2.13.
var getProgress = function() {
var promise = $http({method: 'GET', url: 'http://localhost:8080/project/local/some/getStatus'});
promise.then(function(success) {
alert(JSON.stringify(success));
}, function(error) {
alert(JSON.stringify(error));
}, function(notify) {
alert(JSON.stringify(notify));
});
};
So I'm trying to receive some JSON from my REST web service. To test the service, I access it from the browsers(IE9,Firefox 27, Chrome 33) works fine in all of them.
The above code using angular however, always prompts me with the error:
*{"data":"","status":404,"config":{"transformRequest":[null],"transformResponse":[null],"method":"GET","url":"http://localhost:8080/project/local/some/getStatus"
,"headers":{"Accept":"application/json, text/plain, /"}}}*
Using wireshark I check the HTTP request and HTTP response, both calling the web service from browser and from angular returns 200, and the desired json object!! Nevertheless angular prompts me with 404.
When I make the get request from Firefox USING ANGULAR and debug using Findbugs, in the console I get HTTP Code 200, nevertheless Angular says 404. Tried debuging angular's code to no avail, can't see anything strange.
The above code works correctly in IE9!
Any suggestions are appreciated.
@GeoffGenz && @BKM were right. CORS is to blame. I imagine there are several ways around the problem.
localhost
... Because the protocol is different (file vs http) the request has different origin, as explained in https://developer.mozilla.org/en-US/docs/Web/JavaScript/Same_origin_policy_for_JavaScript . Once deployed in JBoss everything works.I had the same problem. but the cause was simply that I added EnableCors attribute to controller but I forgot to enable CORS in WebAPI configs.
This could also be resolved using IE, IE never uses file:\ before the local html file. The reason why using file:\\ doesn't works with http request has been already explained in above answers.
Try this: