Node.js + express + cors 不工作:挂起的选项请求

Ale*_*y K 5 node.js cors express

我尝试了大约 10 个不同的选项,但无法让我的 POST 请求开始工作,而是有选项请求处于待处理状态并且永远不会完成

服务器.js

var express = require('express');
var path = require('path');
var mongoose = require('mongoose');
var bodyParser = require('body-parser');
var cors = require('cors');

var app = express();

app.use(cors());

var allowCrossDomain = function(req, res, next) {
  res.header('Access-Control-Allow-Origin', '*');
  res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE,OPTIONS');
  res.header('Access-Control-Allow-Headers', 'Content-Type, Authorization, Content-Length, X-Requested-With, Accept');

  // intercept OPTIONS method
  if ('OPTIONS' == req.method) {
      res.send(200);
  } else {
      next();
  }
};
app.use(allowCrossDomain);

app.options('*', cors());

app.use(require('./routes/order-templates.js'));
app.use(require('./routes/statuses.js'));
app.use(require('./routes/fields.js'));
app.use(require('./routes/users.js'));
app.use(require('./routes/groups.js'));
app.use(require('./routes/upload.js'));
app.use(require('./routes/feedback.js'));

app.use(require('./routes/order.js'));

app.use(express.static('public'));

var mongoDB = 'mongodb://localhost/ior';

mongoose.connect(mongoDB, {
  useMongoClient: true
});

app.get('*', function (request, response) {
  response.sendFile(path.resolve(__dirname, 'public', 'index.html'))
})

app.listen(3000, function () {
  console.log('Fired at ' + Date());
});
Run Code Online (Sandbox Code Playgroud)

用户.js

var express = require('express');
var router = express.Router();

var User = require('../model/user.js');
var bodyParser = require('body-parser');

var app = express();

var cors = require('cors')

var corsOptions = {
    origin: 'http://188.225.82.166:3000/',
    optionsSuccessStatus: 200 
}

app.use(cors())
app.use(bodyParser.json());

app.options('/users/auth/', cors(corsOptions))
app.post('/users/auth/', cors(), function (req, res, next) {
    User.findOne({"mail": req.body.mail, "password": req.body.password}, function (err, user) {
        if (err) throw err;
        if (user == undefined) {
            res.send({"result": "error" })
            res.sendStatus(200)
        } else {
            res.send({"result": "ok", "_id": user._id, "type": user.type })
        }
    });
})

module.exports = app
Run Code Online (Sandbox Code Playgroud)

如果我做

app.use(cors());

app.use(function(req, res, next) {
    console.log('After CORS ' + req.method + ' ' + req.url);
    next();
});
Run Code Online (Sandbox Code Playgroud)

在server.js中我得到

After CORS GET /
After CORS GET /bundle.js
After CORS GET /bootstrap.css.map
After CORS GET /favicon.ico
Run Code Online (Sandbox Code Playgroud)

触发发布请求后,控制台中不会打印任何内容。还值得一提的是,只有当我使用 ubuntu 部署到服务器时才会出现此问题。在本地 mac os 机器上一切都很好

Abh*_*ain 8

您应该在 bodyParser 之前使用 cors 并允许它进行 PUT/DELETE。

// Add cors
app.use(cors());
app.options('*', cors());  // enable pre-flight
app.use(bodyParser.json());
Run Code Online (Sandbox Code Playgroud)


小智 5

这可能对像我这样的人有帮助:一开始我认为这是服务器端问题,但后来 cors 错误的原因变成了我的前端。我正在向localhost:3000/api而不是发送请求 就是http://localhost:3000/api 这样


par*_*rth 0

尝试这个。在 user.js 文件中使用 router.post 而不是 app.post。

router.post('/users/auth/', cors(), function (req, res, next) {
    User.findOne({"mail": req.body.mail, "password": req.body.password}, function (err, user) {
        if (err) throw err;
        if (user == undefined) {
            res.send({"result": "error" })
            res.sendStatus(200)
        } else {
            res.send({"result": "ok", "_id": user._id, "type": user.type })
        }
    });
})
Run Code Online (Sandbox Code Playgroud)

然后导出router模块

module.exports = router;
Run Code Online (Sandbox Code Playgroud)

我还建议在 server.js 文件中使用 bodyparser 。所以你不需要在每个文件中使用它。