IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> 【小河今学 | webSocket】一个简单的聊天室实现 -> 正文阅读

[网络协议]【小河今学 | 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.运行结果

在这里插入图片描述

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-09-30 01:21:54  更:2022-09-30 01:23:37 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年4日历 -2024/4/26 0:18:52-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码