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.百度文档

相关推荐
聿琴惜荭顏丶29 分钟前
.NET MAUI进行UDP通信(二)
网络协议·udp·.net
努力的小T33 分钟前
基于 Bash 脚本的系统信息定时收集方案
linux·运维·服务器·网络·云计算·bash
TS_forever0071 小时前
【华为路由的arp配置】
网络·华为
hkNaruto1 小时前
【P2P】基于 Nebula 的 P2P 通信技术的虚拟局域网游戏设计方案
网络协议·游戏·p2p
Andya_net2 小时前
网络安全 | 0day漏洞介绍
网络·安全·web安全
某风吾起2 小时前
linux系统中的 scp的使用方法
linux·服务器·网络
NoneCoder2 小时前
JavaScript系列(42)--路由系统实现详解
开发语言·javascript·网络
阿猿收手吧!2 小时前
【Linux网络总结】字节序转换 收发信息 TCP握手挥手 多路转接
linux·服务器·网络·c++·tcp/ip
小何只露尖尖角2 小时前
网络层-IP协议
网络
Themberfue3 小时前
UDP/TCP ③-拥塞控制 || 滑动窗口 || 流量控制 || 快速重传
网络·网络协议·tcp/ip·计算机网络·udp