Access-Control-Allow-Origin不允许使用原始http:// localhost

问题描述

如果您希望每个人都可以访问Node应用程序,请尝试使用

res.header('Access-Control-Allow-Origin', "*")

这将允许来自任何来源的请求。该CORS使网站有大量的信息在不同的访问控制允许标题和如何使用它们。

我使用的是Chrome浏览器,请看看对于本地主机和访问控制允许来源错误的bug。这里还有另一个,详细说明了该问题。

解决方法

我正在尝试从lobb.js到我的node.js服务器的访存。但是,我在控制台中收到以下错误:

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

我将以下内容添加到我的node.js服务器中:

var allowCrossDomain = function(req,res,next) {
    res.header('Access-Control-Allow-Origin',"http://localhost");
    res.header('Access-Control-Allow-Methods','GET,PUT,POST,DELETE');
    res.header('Access-Control-Allow-Headers','Content-Type');
};

app.configure(function() {
    app.use(allowCrossDomain);
});

但是它仍然返回相同的错误。但是,即使这确实可行,也不是理想的解决方案,因为我希望所有用户都能够发送请求。