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

相关推荐
ccieluo10 分钟前
华为eNSP网络工程毕业设计 基于双出口智能选路的中小型企业网络设计 策略路由 IPSec SSL 无线网络 BGP
网络·华为·毕业设计
青火coding11 分钟前
ai时代下的RPC传输——StreamObserver
qt·网络协议·microsoft·rpc
lpfasd12321 分钟前
《影响力》精读笔记
网络·笔记·成长
枫叶丹428 分钟前
【Qt开发】Qt系统(九)-> Qt TCP Socket
c语言·开发语言·网络·c++·qt·tcp/ip
独行soc1 小时前
2026年渗透测试面试题总结-7(题目+回答)
java·网络·python·安全·web安全·渗透测试·安全狮
EverydayJoy^v^2 小时前
RH134简单知识点——第6章——管理SELinux安全性
linux·服务器·网络
码路星河9 小时前
基于 Vue + VueUse 的 WebSocket 优雅封装:打造高可用的全局连接管理方案
javascript·vue.js·websocket
橙河网络10 小时前
橙河网络:海外问卷安全类问卷调查怎么做?
网络·经验分享·笔记·课程设计
扶苏-su10 小时前
Java网络编程:InetAddress 详解
java·开发语言·网络
Tandy12356_10 小时前
手写TCP/IP协议栈——HTTP协议实现(完结篇)
c语言·网络·网络协议·tcp/ip·计算机网络·http