使用角度http.post方法发布 - xmlhttprquest无法加载服务

时间:2013-10-06 17:23:13

标签: json google-chrome firefox angularjs xmlhttprequest

Angular $ http.post方法未将JSON发布到服务(RESTFul服务,节点服务)。 显示以下错误:

XMLHttpRequest cannot load /some/service. Invalid HTTP status code 404

这是发布的代码

$http({method:'POST', url:'/some/service/',data:{"key1":"val1","key2":"val2"}}).success(function(result){
  alert(result);
});

相同的代码正在使用旧版本的chrome,即v29。。*。我将我的Chrome更新为V30。。*。现在,它没有用。也不在Firefox中工作。 Chrome和Firefox有问题吗?

有人可以帮忙吗?

2 个答案:

答案 0 :(得分:2)

在将Chrome更新到版本30.0.1599.101之后,我遇到了类似的问题,结果证明是服务器问题。

我的服务器使用Express(http://expressjs.com/)实现,下面的代码允许CORS(How to allow CORS?)运行良好:

var express = require("express");
var server = express();

var allowCrossDomain = function(req, res, next) {
    res.header('Access-Control-Allow-Origin', req.headers.origin || "*");
    res.header('Access-Control-Allow-Methods', 'GET,POST,PUT,HEAD,DELETE,OPTIONS');
    res.header('Access-Control-Allow-Headers', 'content-Type,x-requested-with');
    next();
}
server.configure(function () {
    server.use(allowCrossDomain);
});

server.options('/*', function(req, res){
    res.header('Access-Control-Allow-Origin', req.headers.origin || "*");
    res.header('Access-Control-Allow-Methods', 'GET,POST,PUT,HEAD,DELETE,OPTIONS');
    res.header('Access-Control-Allow-Headers', 'content-Type,x-requested-with');
    res.send(200);
});

server.post('/some_service', function (req, res) {
  res.header('Access-Control-Allow-Origin', req.headers.origin);

  // stuff here

  //example of a json response
  res.contentType('json');
  res.send(JSON.stringify({OK: true}));
});

HTTP请求如下:

$http({
    method: 'POST',
    url: 'http://localhost/some_service',
    data: JSON.stringify({
        key1: "val1",
        key2: "val2"
    }),
    headers: {
        'Content-Type': 'application/json; charset=utf-8'
    }
}).success(
    function (data, status, headers, config) {
        //do something
    }
).error(
    function (data, status, headers, config) {
        //do something
    }
);

正如此处所指出的那样(https://stackoverflow.com/a/8572637/772020),我们的想法是确保您的服务器正确处理OPTIONS请求以启用CORS。

答案 1 :(得分:0)

嗯,几天前发布了一个新的Chrome更新。如果他们更改了与安全相关的任何内容,请检查该版本的补丁说 我的扩展程序几天前在FF和Chrome中都停止了工作。