websocket实现一个局域网在线摸鱼聊天室

1.思路

新建两个项目:

第一个前端项目,搭建聊天室页面,同时使用Websocket API,与服务端进行通信

第二个项目,使用node环境,下载ws包,搭建服务

年前就发现下包有问题,年后老淘宝镜像已经崩了,完全用不了,现在改https://registry.npmmirror.com

2.前端代码

html 复制代码
<template>
    <div class="container">
        <div class="messageBox"></div>
        <textarea class="message"></textarea>
        <button class="send">发送</button>
    </div>
</template>
<script>
export default {
  name: 'weChat',
  data () {
    return {

    }
  },
  mounted () {
    this.initWeChat()
  },
  computed: {
  },
  methods: {
    initWeChat () {
      const messageBox= document.querySelector('.messageBox')
      const textarea = document.querySelector('.message')
      const sendButton = document.querySelector('.send')
      // 生成WebSocket对象
      const ws = new WebSocket('ws://'改成你的ip':9001/ws')

      // 为WebSocket添加事件监听
      ws.addEventListener('message', function (event) {
        const div = document.createElement('div')
        const time = this.getTime()
        div.innerText = event.data+''+time
        messageBox.append(div)
      })
      
      ws.addEventListener('open', () => {
        alert('websocket连接建立完毕')
      })

      sendButton.addEventListener('click', () => {
        // 发送消息
        ws.send(textarea.value)
      })
    },
   getTime () {
      const now = new Date()
      const year = now.getFullYear()
      const month = String(now.getMonth() + 1).padStart(2, '0')
      const day = String(now.getDate()).padStart(2, '0')
      const hour = String(now.getHours()).padStart(2, '0')
      const min = String(now.getMinutes()).padStart(2, '0')
      const second = String(now.getSeconds()).padStart(2, '0')
      return `${year}-${month}-${day} ${hour}-${min}-${second}`
    }
  }
}
</script>
<style lang='scss'  scoped>
//样式自己写去吧
</style>

3.node服务

javascript 复制代码
// 导入WebSocket模块:
const WebSocket = require('ws')

// 引用Server类:
const WebSocketServer = WebSocket.Server

// 实例化:
const wss = new WebSocketServer({
  port: 9001,
  path: '/ws'
})

const wsList = []

// 监听创建连接事件,回调函数的参数是创建的连接
wss.on('connection', function connection (ws) {
  ws.on('error', console.error)

  // 监听该连接的接收信息事件
  ws.on('message', function message (data) {
    console.log('接收到信息: %s', data)
    for (const w of wsList) {
      if (w.readyState == w.OPEN) {
        w.send(data.toString())
      }
    }
  })

  wsList.push(ws)
})
//node wechat.js 启动服务

4.参考文档

1.mdn websocket文档
2.百度文档

相关推荐
自动跟随5 小时前
UWB自动跟随技术全栈解析:从定位算法到“位控一体化“
java·网络·人工智能
长和信泰光伏储能5 小时前
远离电网的底气:离网光伏系统核心原理与搭建要点
网络
天天进步20156 小时前
Tunnelto 源码解析 #8:多路复用机制:StreamId、ActiveStreams 与并发请求生命周期
网络
数智化管理手记6 小时前
标准作业越推越虚?重塑认知、规避误区,破解精益落地形式主义
大数据·网络·精益工程
路由侠内网穿透7 小时前
本地部署开源自托管服务器监控系统哪吒监控并实现外部访问
运维·服务器·网络协议
上海云盾-小余8 小时前
SSL 证书部署误区避坑:加密部署与防劫持落地教程
网络协议·iphone·ssl
国科安芯8 小时前
ASP7A84AS——航天级低噪声高PSRR线性稳压器
网络·单片机·嵌入式硬件·架构·安全性测试
以太浮标9 小时前
华为eNSP模拟器综合实验之- 路由黑洞场景解析及实验
运维·网络·网络协议·网络安全·华为·智能路由器·信息与通信
北京耐用通信9 小时前
耐达讯自动化 Modbus RTU转Profibus 网关产品技术说明书
人工智能·物联网·网络协议·自动化·信息与通信
MetrixAeroCore9 小时前
Metrix 国际物联网卡资费及套餐 — 全球流量池·按量付费·无隐形费
网络