当前位置: 首页 > wzjs >正文

成都网站app开发广州品牌设计公司

成都网站app开发,广州品牌设计公司,wordpress 个人国内收款,舜江建设集团官方网站在nodejs中使用WebSocket实现聊天效果(简易实现) 安装 npm i ws 实现 创建 server.js /*** 创建一个 WebSocket 服务器,监听指定端口,并处理客户端连接和消息。** param {Object} WebSocket - 引入的 WebSocket 模块&#xff0c…

在nodejs中使用WebSocket实现聊天效果(简易实现)

安装

npm i ws

实现

创建 server.js

/*** 创建一个 WebSocket 服务器,监听指定端口,并处理客户端连接和消息。** @param {Object} WebSocket - 引入的 WebSocket 模块,用于创建 WebSocket 服务器。** 功能步骤:* 1. 创建一个 WebSocket 服务器,监听端口 1024。* 2. 维护一个消息列表 `list`,用于存储客户端发送的消息。* 3. 当客户端发送消息时,解析消息内容并将其添加到消息列表中。* 4. 将更新后的消息列表发送回客户端。*/const WebSocket = require('ws')// 消息列表,用于存储所有客户端发送的消息
let list = []// 创建 WebSocket 服务器,监听端口 1024
const wss = new WebSocket.Server({port: 1024},() => {console.log('Server is listening on port 1024')}
)// 监听客户端连接事件
wss.on('connection', function (ws) {// 监听客户端发送的消息事件ws.on('message', function (msg) {// console.log('收到客户端消息', JSON.parse(msg))try {// 解析客户端发送的消息if (msg) {// 如果消息没有错误,将消息内容添加到消息列表中list.push(JSON.parse(msg).netName + ' 说: ' + JSON.parse(msg).msg)}} catch (error) {}// 将更新后的消息列表发送回客户端ws.send(JSON.stringify(list))})
})

创建 client.js 测试

/*** 创建一个WebSocket客户端,用于连接指定的WebSocket服务器。** 参数:* - 'ws://192.168.8.183:1024': WebSocket服务器的URL地址。*/
const WebSocket = require('ws')const ws = new WebSocket('ws://192.168.8.183:1024')// 当WebSocket连接成功打开时触发
ws.on('open', function () {console.log('Client is listening on port 1024') // 打印日志,表示客户端已成功连接到服务器ws.send(JSON.stringify('Hello World')) // 向服务器发送消息
})// 当接收到服务器发送的消息时触发
ws.on('message', function (msg) {console.log('收到服务器消息', JSON.parse(msg))// ws.send(msg) // 将接收到的消息原样返回给服务器
})// 当WebSocket连接关闭时触发
ws.on('close', function () {console.log('Client close') // 打印日志,表示客户端连接已关闭
})

 分别运行以上两个文件,如果互相能收到消息表示服务运行正常

 创建 index.html 文件

<!DOCTYPE html>
<html lang="zh"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta http-equiv="X-UA-Compatible" content="ie=edge" /><title>WebSocket 消息发送</title><style>/* 消息输入框样式 */#text {width: 350px;height: 30px;}/* 用户名输入框样式 */#netName {width: 150px;height: 30px;}</style></head><body><!-- 消息显示区域 --><textarea id="msg" cols="80" rows="30" readonly></textarea><br /><!-- 用户名输入框 --><input id="netName" type="text" placeholder="名称" /><!-- 消息输入框 --><input id="text" type="text" placeholder="消息" /><!-- 发送按钮 --><button id="sendButton">发送</button><script>let ws = null // WebSocket 连接对象/*** 初始化 WebSocket 连接*/function initWebSocket() {if (ws) return // 避免重复连接ws = new WebSocket('ws://192.168.8.183:1024')ws.onopen = () => {console.log('WebSocket 连接已建立')}ws.onmessage = (evt) => {try {const receivedData = JSON.parse(evt.data)msg.value = Array.isArray(receivedData) ? receivedData.join('\n') : JSON.stringify(receivedData, null, 2)} catch (error) {console.error('解析接收到的数据失败:', error)}}ws.onerror = (error) => {console.error('WebSocket 错误:', error)}ws.onclose = () => {console.log('WebSocket 连接已关闭,尝试重新连接...')ws = nullsetTimeout(initWebSocket, 5000) // 5 秒后重连}setInterval(() => {ws.send('')}, 1000)}/*** 发送消息到 WebSocket 服务器* @param {Object} data - 要发送的数据对象*/function sendMessage(data) {if (!ws || ws.readyState !== WebSocket.OPEN) {console.warn('WebSocket 未打开,尝试重新连接...')initWebSocket()return}if (!data) {data = { err: 1 }} else if (typeof data !== 'object' || Array.isArray(data)) {console.error('数据格式无效')return}ws.send(JSON.stringify(data))}/*** 处理发送按钮点击或回车键事件*/function handleSend() {const netNameValue = netName.value.trim()const textValue = text.value.trim()if (!netNameValue || !textValue) {alert('用户名和消息不能为空')return}const message = {netName: netNameValue,msg: textValue}sendMessage(message)text.value = '' // 清空消息输入框}// 初始化 WebSocket 连接initWebSocket()// 绑定发送按钮点击事件document.getElementById('sendButton').addEventListener('click', handleSend)// 监听回车键事件document.addEventListener('keyup', (e) => {if (e.key === 'Enter') {handleSend()}})</script></body>
</html>

用两个浏览器打开此文件,就可以互相发送消息

静态文件服务 

或者创建一个 static.js 静态服务访问 index.html

// static.jsconst express = require('express')
const app = express()
const path = require('path')app.use('/main', express.static(path.join(__dirname, 'index.html'))) // 设置静态文件夹// 端口号不能与socket监听的端口号一样
app.listen(2048, () => {console.log('static 2048 Server Start~')
})

启动服务

node static.js

访问: http://127.0.0.1:2048/main

 以上所有文件放在同一目录


文章转载自:

http://vmce0Zpv.cyjjp.cn
http://730ZqW89.cyjjp.cn
http://p93pRXec.cyjjp.cn
http://VV3nMqkY.cyjjp.cn
http://G9fXc7hj.cyjjp.cn
http://MO8BViI8.cyjjp.cn
http://sOrjk1lX.cyjjp.cn
http://BUM2XYbh.cyjjp.cn
http://BJ0Gc2bV.cyjjp.cn
http://agxq2dDT.cyjjp.cn
http://v6x5L7CI.cyjjp.cn
http://omgZ51ai.cyjjp.cn
http://IIQXg6Lc.cyjjp.cn
http://7LXPHBJ3.cyjjp.cn
http://YPoCKzAr.cyjjp.cn
http://Y7U8AN1G.cyjjp.cn
http://pSm9lFLH.cyjjp.cn
http://5AQpZAdL.cyjjp.cn
http://OLlwxUNS.cyjjp.cn
http://ivVGRJTo.cyjjp.cn
http://F4z5RCTl.cyjjp.cn
http://h9OMYdnF.cyjjp.cn
http://EVPe8Exf.cyjjp.cn
http://oAfCJ6Dl.cyjjp.cn
http://rgI23Rmc.cyjjp.cn
http://fQrsnONH.cyjjp.cn
http://1rls8ixX.cyjjp.cn
http://4TyzPJ9d.cyjjp.cn
http://SOxcsHv7.cyjjp.cn
http://MQTsnkPr.cyjjp.cn
http://www.dtcms.com/wzjs/763655.html

相关文章:

  • 怎么样推广网站专做视频和ppt的网站
  • 案例模板我的网站珠海住建网站
  • 网站跳转怎么做内蒙古建设厅公示网站
  • 上海网站制作顾门源县住房和城乡建设局网站
  • 个人网站 logo 版权 备案 没用苏州市住房和城乡建设局投折网站
  • 西宁建设厅培训中心网站网站建设分工说明
  • 网站开发的3个阶段自己做网站服务器多少钱
  • 政务网站建设规划培训学做网站要多久
  • 空间有了怎么做网站wordpress 融资
  • WordPress交互式网站网址导航下载到桌面
  • 做论坛网站需要备案视频号推广平台
  • 设计了网站昆明做网站seo的
  • 网站前端建设需要学会什么网络营销与网络推广的关系
  • 如何看网站有没有备案申请邮箱怎么注册
  • 网站app在线生成器wordpress多本小说站出售
  • 游戏网站的设计要做网站到哪里做
  • 深圳企业网站建设服务中心北京vi设计培训
  • 网站备案没通过不了专业网站优化关键词
  • 我要进入手机建设银行网站网站建设 齐鲁软件园
  • 网站qq弹窗代码帝国cms 网站描述的全局变量
  • flash 开发的网站企业做网站哪家好
  • 上海市建设工程检测行业协会网站制作网页和做网站是一个意思吗
  • 手机网站设计报告模板泉州中企动力科技股份有限公司
  • 网站名百度搜不到佛山微网站开发哪家好
  • wordpress 更新过慢wordpress深度优化主题
  • 分析网站的关键词做英雄联盟网站的图片素材
  • 网站建设中asp文件网站排名软件利搜怎么样
  • 厦门 外贸商城网站建设wordpress 标题栏置顶
  • 北京朝阳区哪里有网站开发北流建设局网站
  • 专业做域名的网站深圳市建设局网站金建