Aus*_*vis 4 node.js cors express angularjs
出于某种原因,每当我尝试将一些数据发布到我的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.
Run Code Online (Sandbox Code Playgroud)
这是我的客户端角度JS代码试图发送一些简单的数据.此代码当前正在位于的nginx服务器上运行http://localhost:8080
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, status, headers, config) {
console.log('error');
});
};
}
Run Code Online (Sandbox Code Playgroud)
这是我的节点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);
});
Run Code Online (Sandbox Code Playgroud)
Ray*_*lus 10
如错误消息所述,您必须在对预检的响应中确认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");
| 归档时间: |
|
| 查看次数: |
6893 次 |
| 最近记录: |