使用nodejs+express作为后台提供接口,设置res.header时的疑问?

我现在在使用nodejs+express开发一个博客,并提供接口给前端。
前端是我用vue写的单页应用。
现在我有在本地开了两个端口不同的服务,所以涉及到跨域。因为跨域需要设置返回头,以支持跨域,我写的代码如下:

exports.getPostList = function (req, res) {
  PostModel.getPosts()
    .then(function (posts) {
      res.header('charset', 'utf8');
      res.header('Access-Control-Allow-Origin', '*');      return res.status(200).json({data: posts, status: 'success'});
    })
    .catch(function(err) {      // next();
      return res.status(401).send(err);
    });
}

现在我有一个疑问,有什么办法可以全局设置res.header('Access-Control-Allow-Origin', '*');,
因为现在我需要在每个接口里都单独设置,我觉得很不妥啊,希望大神给个思路,谢谢!


慕码人2483693
浏览 2075回答 1
1回答

侃侃尔雅

可以再express的app入口设置var app = express(); app.all('*', function(req, res, next) {     res.header("Access-Control-Allow-Origin", "*");     res.header("Access-Control-Allow-Headers", "X-Requested-With");     res.header("Access-Control-Allow-Methods","PUT,POST,GET,DELETE,OPTIONS");     res.header("X-Powered-By",' 3.2.1')     res.header("Content-Type", "application/json;charset=utf-8");     next(); });
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript