基于Node.js和ws库搭建WebSocket服务并实现消息互通的简单示例

环境要求:

  • Node.js环境安装
  • npm(Node.js的包管理器)

步骤:

  1. 安装Node.js:如果你还没有安装Node.js,请从Node.js官网下载并安装。

  2. 创建项目:创建一个新的目录作为项目文件夹,并在该目录下初始化一个新的Node.js项目。

        mkdir my-websocket-server
        cd my-websocket-server
        npm init -y
    3. 安装WebSocket库:使用npm来安装ws库。

        npm install ws
    4. 创建WebSocket服务端:在项目目录中创建一个名为server.js的文件,并添加以下代码:

const WebSocket = require('ws');

const wss = new WebSocket.Server({ port: 8080 });

wss.on('connection', function connection(ws) {
  ws.on('message', function incoming(message) {
    console.log('received: %s', message);
    // 广播消息到所有客户端
    wss.clients.forEach(function each(client) {
      if (client !== ws && client.readyState === WebSocket.OPEN) {
        client.send(message);
      }
    });
  });

  ws.send('你已连接到WebSocket服务器');
});

console.log('WebSocket服务正在监听8080端口...');
这段代码创建了一个监听8080端口的WebSocket服务器。服务器会接收客户端发送的消息,并将它广播给所有其他已连接的客户端。

5. 运行WebSocket服务端:在终端中运行服务端代码 

node server.js
6. 创建WebSocket客户端
可以使用任何支持WebSocket的客户端来连接这个服务器。这里我们以浏览器为例,创建一个简单的HTML页面作为客户端。

在项目目录中创建一个名为client.html的文件,并添加以下代码:

<!DOCTYPE html>
<html>
<body>
  <script>
    var ws = new WebSocket('ws://localhost:8080');

    ws.onopen = function() {
      console.log('连接服务器成功!');
      ws.send('你好,服务器!');
    };

    ws.onmessage = function(evt) {
      console.log('收到服务器消息:' + evt.data);
    };

    ws.onclose = function() {
      console.log('与服务器断开连接');
    };

    ws.onerror = function(err) {
      console.error('连接出错:', err);
    };
  </script>
</body>
</html>

这个HTML页面会在打开时尝试连接到WebSocket服务器,并在连接成功后发送一条消息。它还能够接收并显示从服务器收到的消息。

7. 打开客户端页面
使用浏览器打开client.html文件,你应该能在控制台中看到与WebSocket服务器的交互过程。

  • 33
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现基于Node.jsWebSocket聊天室,可以使用nodejs-websocket和socket.io这两个模块。首先,需要在Node.js环境中安装这两个模块。 使用nodejs-websocket模块的实现示例如下所示: ```javascript var ws = require("nodejs-websocket"); var server = ws.createServer(function(conn){ conn.on("text", function(data){ // 处理客户端发送的消息 console.log("Received message from client: " + data); // 向所有连接的客户端广播消息 server.connections.forEach(function(connection){ connection.sendText(data); }); }); conn.on("close", function(code, reason){ // 处理客户端断开连接的事件 console.log("Client disconnected"); }); }).listen(8000); console.log("WebSocket server listening on port 8000"); ``` 而使用socket.io模块的实现示例如下所示: ```javascript var app = require("http").createServer(); var io = require("socket.io")(app); io.on("connection", function(socket){ socket.on("message", function(data){ // 处理客户端发送的消息 console.log("Received message from client: " + data); // 向<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [websocket简明教程(nodejs-websocket、socket.io实现Web聊天室)](https://blog.csdn.net/qq_32252957/article/details/88586497)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值