微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

node.js – 使用nodejs和AngularJS的CORS问题

出于某种原因,每当我尝试将一些数据发布到我的api服务器时,我都会遇到以下两个错误.

OPTIONS http://localhost:3000/test2 Request header field Content-Type is not allowed by Access-Control-Allow-Headers. angular.min.js:99
XMLHttpRequest cannot load http://localhost:3000/test2. Request header field Content-Type is not allowed by Access-Control-Allow-Headers.

这是我的客户端角度JS代码试图发送一些简单的数据.此代码当前在位于http:// localhost:8080下的Nginx服务器上运行

function Controller($scope,$http) {
    //scope is all of the elements within the controller declared on the html
    var url = 'http://localhost:3000/test2';

    $scope.listVaules = function () {
        console.log("about to post user id");
        console.log($scope.user.userId);
        console.log($scope.user.name);
        console.log($scope.user.password);
        console.log(JSON.stringify($scope.user));
        $http({ method: 'Post',url: url,data: JSON.stringify($scope.user) }).
            success(function (data,status,headers,config) {
                console.log(data);
                console.log('success');
            }).
            error(function (data,config) {
                console.log('error');
            });
    };
    }

这是我的节点JS代码来处理“处理”对localhost:3000 / test2的请求

// CORS header securiy
app.all('/*',function (req,res,next) {
  res.header("Access-Control-Allow-Origin","*");
   res.header('Access-Control-Allow-Methods','GET,PUT,POST,DELETE');
  res.header("Access-Control-Allow-Headers","X-Requested-With");
  next();
});

//Should post client side json info to the server
app.post(url + '/test2',function(req,res) {
    var name = req.body.name;
    var userId = req.body.userId;
    var password = req.body.password;

    console.log(name + ' ' + userId + ' ' + password);
    res.send(200);
});

解决方法

错误消息所述,您必须在对预检的响应中确认Content-Type标头.这可能是由您的请求的非“简单”Content-Type引起的(表面上是application / json).

所以,而不是这个:

res.header(“Access-Control-Allow-Headers”,“X-Requested-With”);

…你需要这个:

res.header(“Access-Control-Allow-Headers”,“X-Requested-With,Content-Type”);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐