使用 CORS 与 LocomotiveJs 一起休息 API。适用于本地机器,但不适用于 Amazon 或 Heroku
我使用 LocomotiveJs 做了一个 REST api,现在我正在尝试在其上启用 CORS。我将以下代码添加到我的“所有”环境(config/environments/all.js)中。
this.use(function crossOrigin(req,res,next){
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers", "X-Requested-With,Authentication");
res.header("Access-Control-Allow-Methods","GET,POST,PUT,DELETE,OPTIONS");
return next();
});
它可以在我的本地机器上运行,但是当我将它部署到 Heroku 或 AWS 时,当客户端发送 OPTIONS 命令时出现 404 Http 错误。
为了隔离问题,我开发了一个简单的 Express 应用程序,代码如下:
var express = require('express');
var app = express();
app.all('*', function(req, res, next) {
res.header("Access-Control-Allow-Origin", "*");
res.header("Access-Control-Allow-Headers", "X-Requested-With,Authentication");
next();
});
app.get('/test', function(req, res){
res.set('Content-Type', 'application/json');
res.send({ 'Hello' : 'World' });
});
var port = process.env.PORT || 5000;
app.listen(port);
console.log('Listening on port ' + port);
并且此代码在部署到 Heroku 时有效!
你们对为什么它在我的本地机器上工作而在服务器上没有工作有任何意见吗?