javascript - XMLHttpRequest 无法加载 http ://localhost:3000/get

标签 javascript ajax node.js cors

我正在从 Tomcat 中运行的另一个程序调用 Node js 服务,当我使用下面的代码时一切都很好。

var express = require('express')
  , routes = require('./routes')
  , user = require('./routes/user')
  , http = require('http')
  , path = require('path'),

var app = express();

// all environments
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));

// development only
if ('development' == app.get('env')) {
  app.use(express.errorHandler());
}

app.get('/get', function (req, res) {
    // Website you wish to allow to connect
    res.setHeader('Access-Control-Allow-Origin', '*');

    // Request methods you wish to allow
    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');

    // Request headers you wish to allow
    res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');

    // Set to true if you need the website to include cookies in the requests sent
    // to the API (e.g. in case you use sessions)
    res.setHeader('Access-Control-Allow-Credentials', true);

      res.send('Hello World!');
    });


http.createServer(app).listen(app.get('port'), function(){
  console.log('Express server listening on port ' + app.get('port'));
});

但是为了最小化代码,我向其中引入了中间件,如下所示,

var express = require('express')
  , routes = require('./routes')
  , user = require('./routes/user')
  , http = require('http')
  , path = require('path'),

var app = express();
var allowCrossDomain = function(req, res, next) {
        // Website you wish to allow to connect
    res.setHeader('Access-Control-Allow-Origin', '*');

    // Request methods you wish to allow
    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');

    // Request headers you wish to allow
    res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');

    // Set to true if you need the website to include cookies in the requests sent
    // to the API (e.g. in case you use sessions)
    res.setHeader('Access-Control-Allow-Credentials', true);
   next();
}

// all environments
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(allowCrossDomain);
app.use(express.static(path.join(__dirname, 'public')));

// development only
if ('development' == app.get('env')) {
  app.use(express.errorHandler());
}

app.get('/get', function (req, res) {
      res.send('Hello World!');
    });


http.createServer(app).listen(app.get('port'), function(){
  console.log('Express server listening on port ' + app.get('port'));
});

此时我得到XMLHttpRequest无法加载http://localhost:3000/get 。请求的资源上不存在“Access-Control-Allow-Origin” header 。来源'http://localhost:8083 ' 因此不允许访问。,我不知道在哪里丢失了它。

最佳答案

这是我的解决方法,希望对你有帮助。

var express = require('express'),
    routes = require('./routes'),
    user = require('./routes/user'),
    http = require('http'),
    path = require('path'),

var app = express();
var allowCrossDomain = function(req, res, next) {
        // Website you wish to allow to connect
    res.setHeader('Access-Control-Allow-Origin', '*');

    // Request methods you wish to allow
    res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS, PUT, PATCH, DELETE');

    // Request headers you wish to allow
    res.setHeader('Access-Control-Allow-Headers', 'X-Requested-With,content-type');

    // Set to true if you need the website to include cookies in the requests sent
    // to the API (e.g. in case you use sessions)
    res.setHeader('Access-Control-Allow-Credentials', true);
   next();
}

// all environments

app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(allowCrossDomain);
app.use(express.static(path.join(__dirname, 'public')));

// development only
if ('development' == app.get('env')) {
  app.use(express.errorHandler());
}

app.get('/get', function (req, res) {
      res.end('Hello World!');
    });


   app.listen(3000,function(){
  console.log("It's Started on PORT 3000");
}); 

关于javascript - XMLHttpRequest 无法加载 http ://localhost:3000/get,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28515351/

相关文章:

javascript - 在每个 Ajax 调用上重新加载被调用的页面

node.js - 带有标志 'a' 的 nodejs fs.openSync() 无法创建不存在的文件

Javascript 声音开始/停止和图像更改第 2 部分

javascript - 在数组中创建循环迭代列表

Javascript - 添加更多 on.change 选项

node.js - 使用 grunt-contrib-copy 将文件夹结构从 src/复制到 dist/

node.js - 在 where 上使用 Sequelize 函数

javascript - 使用 jquery 对表单中的一系列输入和选择字段进行求和和相乘

javascript - 使用 JavaScript/jQuery 实时附加到 URI/URL 而无需刷新页面位置

javascript - JS/AJAX : Hide/Show select boxes