【问题标题】:Socket.io Cross-domain connections fail; 'XMLHttpRequest cannot load ...'Socket.io 跨域连接失败; 'XMLHttpRequest 无法加载...'
【发布时间】:2013-01-06 04:17:28
【问题描述】:

我正在尝试跨域 socket.io,但我遇到了一个问题: 我总是收到XMLHttpRequest cannot load http://handsonwithnodejs.samarthwiz.c9.io/socket.io/1/?t=1358882710333. Origin https://c9.io is not allowed by Access-Control-Allow-Origin

服务器代码:

var app = require('http').createServer(handler)
  , io = require('socket.io').listen(app)
  , fs = require('fs')

app.listen(process.env.PORT);

function handler (req, res) {
  fs.readFile(__dirname + '/index.html',
  function (err, data) {
    if (err) {
      res.writeHead(500);
      return res.end('Error loading index.html');
    }

    res.writeHead(200);
    res.end(data);
  });
}
io.set('origins', '*:*');
io.sockets.on('connection', function (socket) {
  socket.emit('news', { hello: 'world' });
  socket.on('my other event', function (data) {
    console.log(data);
  });
});

在第 19 行 io.set('origins', '*:*');我尝试将 ':' 替换为 '*', 'https://c9.io', 'c9.io', 'https://c9.io/' 和 '.',有时我会添加类似 'c9.io/' 的内容 我收到警告“非法来源...”,但这只是与 cloud9 相关的问题。

客户端代码:

<html>
<body>
<script src="https://raw.github.com/LearnBoost/socket.io-client/master/dist/socket.io.js"></script>
<script>
  var socket = io.connect('http://handsonwithnodejs.samarthwiz.c9.io');
  socket.on('news', function (data) {
    console.log(data);
    socket.emit('my other event', { my: 'data' });
  });
</script>
</body>

</html>

我知道使用 github 获取我的脚本还不是最好的主意,但我想保持我的代码干净并且错误消息可读('socket.io.min.js' 中的所有内容都在第 2 行)

附: 1.我知道还有其他类似的线程,但它们并没有解决我的问题。 2. 请不要回复'只需将页面托管在与socket.io相同的服务器上'我需要它是跨域的。

【问题讨论】:

  • 这很有趣,我一直试图通过弄乱 Origin xdomain 等来阻止使用我的 Socket.io 的其他域,但到目前为止还没有运气!我可以从任何地方 io.connect 到 MyIP:Port。现在你说你不能从其他域访问。请告诉我如何停止 CORS :)

标签: node.js cross-domain socket.io


【解决方案1】:

我认为您需要在托管客户端代码时设置 Access-Control-Allow-Origin 标头。查看https://developer.mozilla.org/en-US/docs/HTTP/Access_control_CORS 以获取有关标头的更多信息。

出于安全原因,此标头必须由客户端设置。

【讨论】:

  • 我该怎么做呢?从我看到的托管文件的服务器需要设置它,但是根据你的客户端(html文件)设置它。提前致谢。
  • 当我说客户端时,我指的是托管客户端文件的网络服务器,我知道这不是很清楚,抱歉。您如何托管客户端 HTML 文件?
  • 我认为可能有一个 JavaScript 函数,如 set('access.control', '*'),谢谢。我现在在 cloud9 上托管,完成后我将部署到手机间隙。
  • @Samarthwiz 你有没有解决这个问题?我这里stackoverflow.com/questions/27265742/…也有同样的问题,不知道怎么在cloud9中设置访问控制
  • 我没有。我放弃了。
猜你喜欢
  • 2014-10-03
  • 2012-07-16
  • 2012-02-16
  • 2012-05-23
  • 2017-07-23
  • 2017-03-06
  • 2013-12-04
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多