节点表达服务器不响应ajax

Eid*_*dam 5 ajax node.js cors express

我是node.js的新手并且遇到了cors问题.我正在从一个快递服务器向另一个快递服务器发送客户端ajax get请求,但至少我无法从app.all('*', function(req, res, next){console.log("request: "+req)}) GET请求获得响应,如下所示:

$.ajax({
    type: 'GET',
    url: 'http://localhost:8082/request'
});
Run Code Online (Sandbox Code Playgroud)

我还在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', '*')},
Run Code Online (Sandbox Code Playgroud)

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

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

在firefox和chrome中,我没有得到任何响应(我得到了chrome net::ERR_CONNECTION_REFUSED)当我在PC上本地运行节点服务器时,一切正常.curl命令工作正常.有机会,这是托管/端口的问题还是我还缺少什么?

小智 4

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

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

$.ajax({
  url: url,
  type: 'POST',
  data: payload,
  dataType: 'json',
  crossDomain: true
})
Run Code Online (Sandbox Code Playgroud)

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

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();
};
Run Code Online (Sandbox Code Playgroud)

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

app.post(url, cors, function(req, res) {
});
Run Code Online (Sandbox Code Playgroud)

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