【问题标题】:getting the basic socket.io sample to work让基本的 socket.io 示例工作
【发布时间】:2023-04-11 12:35:01
【问题描述】:

我什至无法运行非常基本的 socket.io 示例。例如他们网站欢迎页面上的第一个示例:

var io = require('socket.io').listen(80);

io.sockets.on('connection', function (socket) {
  socket.emit('news', { hello: 'world' });
  socket.on('my other event', function (data) {
    console.log(data);
  });
});

在服务器端和

<script src="/socket.io/socket.io.js"></script>
<script>
  var socket = io.connect('http://localhost');
  socket.on('news', function (data) {
    console.log(data);
    socket.emit('my other event', { my: 'data' });
  });
</script>

在客户端。如果我将服务器端保存在host.js 文件中,将客户端保存在client.htm 文件中,然后运行npm host.js,我会得到

   info  - socket.io started
   warn  - error raised: Error: listen EADDRINUSE

这已经不是真正的预期。然后,对于client.htm(或者至少我认为我应该这样做——将它粘贴到client.htm 文件中),我只得到一个空白屏幕。并不奇怪,因为它首先包含一个不存在的文件/socket.io/socket.io.js,但即使将其更改为host.js(我认为它应该是)也不会改变我只得到一个空白屏幕的事实......

我一无所知。

【问题讨论】:

    标签: javascript node.js socket.io


    【解决方案1】:

    EADDRINUSE 表示地址已被使用,因此无法获取套接字。你机器上的 80 端口上是否已经有其他东西在运行? Web 服务器通常使用 80。

    你也可以在其他端口上试试。

    您看到空白文件的原因是它没有连接到节点服务器(因为它无法获取套接字),因此永远不会调用 on news 事件。它甚至可能连接到在 80 上运行的任何其他东西的套接字,它永远不会发出该事件:)

    解决端口冲突后,运行服务器时,应该只是说:

    信息 - socket.io 已启动

    现在它正在等待连接。

    确保将 htm 行更新到您的端口。例如,如果 81:

    var socket = io.connect('http://localhost:81'); // note the :81
    

    编辑: 我刚刚试了一下,在 htm 文件中我必须设置 socket.io.js 文件的相对路径。通过 npm 安装后,它就在我的目录中。

    <script src="node_modules/socket.io/node_modules/socket.io-client/dist/socket.io.js"></script>
    

    确保路径是相对于 htm 文件的(不以 / 开头)。以下是我发现我的位置的方法:

    find . -name 'socket.io.js'
    

    赢了: 目录 socket.io.js /s

    您还应该使用以下命令运行主机(在 *nix 上您可能需要在前面使用 sudo):

    node host.js
    

    我在尝试示例时所做的最后一件事是将 htm 文件中的几行更改为这样,以便在事件发生时看到一个警告消息框:

    socket.on('news', function (data) {
       alert(JSON.stringify(data));
    

    【讨论】:

    • 端口有关系吗?我尝试了 81,现在它只是在运行主机端时挂起,即它说 info - socket.io started 但它不会返回到命令行。 .htm 页面仍然是空白的,所以这似乎不能解决问题。
    • 它解决了 EADDRINUSE 错误,这是您的第一个问题。是的,这很重要。它也没有挂起 - 服务器正在运行等待通信。所以,现在你已经解决了服务器端问题的一半。
    • 对于问题的客户端,您是否更新了htm页面以连接到localhost:81(不是:81)?
    • 我访问了那个 url,但我机器上的 'localhost' 不是你运行节点服务器的机器。 localhost 是我的机器。
    • 啊,所以它必须是 88.198.109.15:83 而不是 localhost:83。我已经想知道客户端如何正确解决这个 localhost 问题。很好,现在可以了,非常感谢!
    猜你喜欢
    • 2014-06-07
    • 2011-10-09
    • 2014-05-13
    • 2016-11-25
    • 1970-01-01
    • 1970-01-01
    • 2012-08-14
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多