5

我正在 Node.JS 中开发一个 REST Web 服务来使用主干框架。我用 urlRoot: 定义了一个 Person 模型,http://localhost:3000/users并创建了一个请求处理程序,它在接收到 post 请求时将这个人添加到数据库中。

app.post('/users', user.add(db));

exports.add = function(db){
    return function(req,res){

        console.log(req.body);

        var name = req.body.name;
        var age = req.body.age;
        var sex = req.body.sex;
        var job = req.body.job;

        var peopleDb = db.get('people');

        peopleDb.insert({
            'name':name,
            'age':age,
            'sex':sex,
            'job':job
        },function(e,docs){
            if(e){
                console.log(e);
            }else
            {
                res.setHeader('Content-Type','application/json');
                res.setHeader('Access-Control-Allow-Origin','*');
                res.setHeader('Access-Control-Allow-Methods','GET,PUT,POST,DELETE');
                res.writeHead(200);
                res.end(JSON.stringify(docs));
            }
        });
    }
}

当我尝试执行代码时,我在控制台中得到了这个:

Origin http://localhost is not allowed by Access-Control-Allow-Origin.

我从其他答案中读到添加标题:Access-Control-Allow-Origin:*并且Access-Control-Allow-Methods:GET,PUT,POST,DELETE会解决问题,但它对我没有用。我也尝试将这些标头放在 .htaccess 文件中,但没有运气。

有人可以告诉我代码是否有问题或此问题的任何解决方案吗?

4

2 回答 2

19

如果您正在使用express,您可以使用cors包来允许 CORS,而不是编写中间件;

var express = require('express')
, cors = require('cors')
, app = express();

app.use(cors());

app.get(function(req,res){ 
  res.send('hello');
});
于 2013-11-02T14:18:32.833 回答
7

OPTIONS当使用与HTTP 方法相同的路径时,您需要实现响应。我有这个代码允许在整个快递应用程序中使用 CORS:

var app = express()
app.use(function(req, res, next) {
    if (req.headers.origin) {
        res.header('Access-Control-Allow-Origin', '*')
        res.header('Access-Control-Allow-Headers', 'X-Requested-With,Content-Type,Authorization')
        res.header('Access-Control-Allow-Methods', 'GET,PUT,PATCH,POST,DELETE')
        if (req.method === 'OPTIONS') return res.send(200)
    }
    next()
})
// configure your routes
于 2013-11-02T14:10:43.160 回答