【小河今学 | webSocket】一个简单的聊天室实现


前言

在实现聊天室之前,我们需要先简单了解websocket是什么?为什么要用到websocket实现聊天室功能?


一、websocket是什么?

websocket是一种全双工通信的协议。全双工通信即允许数据在两个方向上同时传输,当A➡B的同时B➡A。
而websocket的全双工具体是体现在了客户端和服务端的双向交流上。
这里用轮询来举例说明:轮询是在特定的的时间间隔(如每1秒),由客户端对服务端发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。也就是说如果没有客户端向服务端发送请求,服务端不会主动向客户端提供新的数据

而websocket的全双工就体现在这里,只要客户端向服务端发送一次请求,之后有任何的数据改变服务端都会主动向客户端提供。

因此我们用到websocket来实现聊天室功能。

二、实现步骤

1.创建项目框架

首先创建一个文件夹,命名chat-room(可以不取这个名字)
进入到文件夹中,打开cmd,生成package.json并安装websocket。

npm init -y
npm i socket.io --save

在这里插入图片描述
最后生成文件夹内如下所示
在这里插入图片描述
接着创建websocket服务端,命名为server.js,代码如下:

var http = require('http');
var fs = require('fs');
var ws = require('socket.io');  // 引入socket.io

// 创建一个HTTP服务器
// req 请求对象
// res 响应对象,收到请求之后作出响应
var server = http.createServer(function(req,res){   
    var html = fs.readFileSync('./client.html');    // 通过fs同步读取文件client.html,client.html是发送给客户端的文件
    res.end(html);  // 将文件返回给客户端
}).listen(8080);

var io = ws(server);    // http服务器与ws服务相关联,返回io服务实例

// 监听用户的连接事件,即当用户连接服务器时
io.on('connection',(socket)=>{
    // 用户连接io服务器时输出‘有新用户进入房间’
    console.log('有新用户进入房间');
    // 当有用户发送消息时,接收该消息
    socket.on('message',(obj)=>{
        // 输出该消息(可以不要,这里只是为了方便查看)
        console.log(obj);
        // 将接收到的消息发送给所有客户端
        io.emit('message',obj);
    })
})

接着创建传送给客户端的文件client.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>聊天室</title>
</head>
<body>
    <h2>聊天室</h2>
    <textarea id="text" cols="30" rows="10"></textarea>
    <button id="btn">发送</button>
    <script src="https://cdn.bootcdn.net/ajax/libs/socket.io/4.5.2/socket.io.js"></script>
    <script>
        var socket = io.connect('/');   // 连接io服务器
        var text = document.getElementById('text');
        var btn = document.getElementById('btn');
        var myMessage = '';

        // 点击发送按钮
        btn.onclick = function(){
            var mes = text.value;   // 获得输入的消息
            myMessage = mes;
            socket.send(mes);   // 把消息发送到服务器
            text.value = '';    // 清空文本框
        }

        // 当服务器广播消息时,触发message事件,消息内容在回调函数中
        socket.on('message',(mes)=>{
            var p = document.createElement('p');
            p.innerText = mes;
            if(myMessage == mes){   // 如果是自己发送的消息接收到,则将自己发送的消息颜色改为红色,往右偏移
                p.style.cssText = 'color:red;margin-left:200px';
            }
            document.body.appendChild(p);
        })
    </script>
</body>
</html>

最后,在cmd运行node server

2.运行结果

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值