【问题标题】:node express server doesnt respond on ajaxnode express服务器在ajax上没有响应
【发布时间】:2014-03-29 12:39:29
【问题描述】:

我是 node.js 的新手,遇到了 cors 问题。我正在将客户端 ajax 获取请求从一台快速服务器发送到另一台,但至少我无法从 app.all('*', function(req, res, next){console.log("request: "+req)}) 获得响应 GET 请求类似于:

$.ajax({
    type: 'GET',
    url: 'http://localhost:8082/request'
});

我还在 ajax 中设置标题:

'beforeSend : function(xhr) {
    xhr.setRequestHeader('Access-Control-Allow-Methods', 'POST, GET, OPTIONS');
    xhr.setRequestHeader('Access-Control-Allow-Origin', '*');
    xhr.setRequestHeader('Access-Control-Max-Age', '1000');
    xhr.setRequestHeader('Authorization', '*')},

...或在 node.js 中设置 cors 模块:

var cors = require('cors');
var app = express();
app.use(cors());
app.options('*',cors(),function(){
console.log("preflight")
});

在 firefox 和 chrome 中,我都没有收到任何回复(在 chrome 中我得到了 net::ERR_CONNECTION_REFUSED ) 在我的 PC 上本地运行节点服务器时,一切正常。 curl 命令也可以正常工作。 有没有机会,这是托管/端口的问题,还是我仍然遗漏了什么?

【问题讨论】:

标签: ajax node.js express cors


【解决方案1】:

您不需要在 $ajax 调用中设置 CORS 标头,因为浏览器在 HTTP Response 标头中需要这些标头。

对于跨域 AJAX,请确保在 $ajax 选项上设置 crossDomain 标志:

$.ajax({
  url: url,
  type: 'POST',
  data: payload,
  dataType: 'json',
  crossDomain: true
})

在快速端点中处理 CORS 请求的一种简洁方法是创建一个中间件,您可以将其添加到快速响应跨源请求的路由中:

cors.js

module.exports = function(req, res, next) {
  res.header('Access-Control-Allow-Origin', '*');
  res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE');
  res.header('Access-Control-Allow-Headers', 'Content-Type');  
  next();
};

然后确保将中间件添加到 express 端点:

app.post(url, cors, function(req, res) {
});

【讨论】:

  • 好吧,我终于意识到,我的问题在于设置服务器的 url 地址。我用真实域名替换了我所有的“localhost”,在 node.js 中设置了 cors 模块,一切正常。再次感谢您的时间和想法。
【解决方案2】:

我遇到了同样的问题并解决了这个问题:

app.use(function(req, res, next) {
   res.header("Access-Control-Allow-Origin", "*");
   res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");
   next();
});

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2018-07-30
    • 1970-01-01
    • 2014-05-10
    • 2015-02-12
    • 2020-11-21
    • 2021-07-30
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多