webScoket

webScoket是什么?


  • 支持端对端通讯
  • 可以由客户端发起,也可以有服务端发起
  • 用于消息通知、直播间讨论区、聊天室、协同编辑等

做一个简单的webScoket


客户端配置:

1、新建一个页面叫web-scoket.html

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>webScoket</title>
</head>
<body>
    <p>webScoket</p>
    <button id="btn-send">发送消息</button>
    <script>
        const btnSend = document.getElementById('btn-send')
    </script>
</body>
</html>

服务器端配置:

1、进入一个目录执行npm init -y

注意:执行以上命令,会生成一个package.json的文件

javascript 复制代码
{
  "name": "web-scoket-sever",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [],
  "author": "",
  "license": "ISC"
}

2、安装ws和nodemon插件、以下是安装插件的命令

javascript 复制代码
sudo cnpm i ws
sudo cnpm i nodemon

3、在文件夹下新建一个src目录,在src目录下新建index.js文件

javascript 复制代码
const { WebSocketServer } = require('ws')

//new 一个webScoket服务,端口号为3000
const wsServer = new WebSocketServer({ port: 3000 })

//监听连接connection,
wsServer.on('connection', wx => {
    console.info('connection');

    //监听信息,msg客户端传递过来的信息
    wx.on('message', msg => {
        console.info('收到信息', msg);

        //收到信息2秒后,给客户端一个反馈
        setTimeout(() => {

            //we.send给客户端发送信息
            we.send('服务端已收到信息!' + msg.toString())
        }, 2000)
    })
})

4、修改package.json文件中的代码

javascript 复制代码
 "dev": "nodemon src/index.js"

5、代码执行npm run dev启动服务

相关推荐
测试员周周几秒前
【Appium 系列】第12节-智能路由 — API测试 vs UI 测试的自动选择
开发语言·人工智能·python·功能测试·ui·appium·测试用例
前端那点事2 分钟前
从零落地前端性能优化:全链路避坑+实战调优方案
前端·vue.js
liudanzhengxi10 分钟前
AnthropicAPI连接超时:实战避坑指南
开发语言·php
张二娃同学10 分钟前
01_C语言学习路线与开发环境搭建
c语言·开发语言·学习
沸点小助手15 分钟前
「妈,我真不是修电脑的」获奖名单公示|本周互动话题上新🎊
前端·人工智能
程序leo源16 分钟前
Qt信号与槽深度详解
c语言·开发语言·数据库·c++·qt·c#
水云桐程序员18 分钟前
C++数组详细介绍
开发语言·c++
码界筑梦坊22 分钟前
123-基于Python的特斯拉超级充电站分布数据可视化分析系统
开发语言·python·信息可视化·数据分析·毕业设计·echarts·fastapi
AI人工智能+电脑小能手26 分钟前
【大白话说Java面试题 第56题】【JVM篇】第16题:JVM有哪些垃圾收集器?
java·开发语言·jvm·面试
兵麒麟28 分钟前
JavaScript Promise 完全掌握:从外卖订单到优雅异步
前端