WebSocket 前端node启用ws调试

server.js

<!-- WebSocket 实时通信 -->

<!-- 2 npm install ws -->

<!-- 3 npm list ws 看安装上没-->

<!-- 本地起websocket 创建 WebSocket 服务器文件 server.js -->

<!-- 4 4️⃣ 启动服务器 node server.js -->

复制代码
<!-- WebSocket 实时通信 -->
<!-- 2 npm install ws -->
 <!-- 3 npm list ws  看安装上没-->
<!-- 本地起websocket 创建 WebSocket 服务器文件 server.js -->
 <!-- 4 4️⃣ 启动服务器 node server.js -->
<template>
  <div class="websocket-chat">
    <div class="chat" style="border: 1px solid #ccc; padding: 10px; height: 200px; overflow-y: auto;">
      <p v-for="(msg, index) in messages" :key="index">{{ msg }}</p>
    </div>
    <input
      type="text"
      v-model="messageInput"
      placeholder="Type your message"
      @keyup.enter="sendMessage"
      style="margin-top: 10px; padding: 5px;"
    />
    <button @click="sendMessage" style="margin-left: 5px; padding: 5px 10px;">Send</button>
  </div>
</template>

<script setup lang="ts">
import { ref, onMounted, onBeforeUnmount } from 'vue'

const messages = ref<string[]>([])
const messageInput = ref('')
let socket: WebSocket | null = null
const isConnected = ref(false) // 标识连接状态

onMounted(() => {
  try {
    socket = new WebSocket('ws://localhost:8888')
    // 带token
    // socket = new WebSocket(`wss://api.example.com/ws?token=${userToken}`)

    socket.onopen = (event) => {
      console.log('WebSocket connection opened:', event)
      isConnected.value = true
      messages.value.push('✅ 已连接 WebSocket 服务器')
    }

    socket.onmessage = (event) => {
        //   messages.value.push(`${data.userName}: ${data.content}`)
      messages.value.push('收到: ' + event.data)
    }

    socket.onclose = (event) => {
      console.log('WebSocket connection closed:', event)
      isConnected.value = false
      messages.value.push('❌ WebSocket 已关闭')
    }

    socket.onerror = (event) => {
      console.error('WebSocket error:', event)
      isConnected.value = false
      messages.value.push('⚠️ WebSocket 出错或未连接')
    }
  } catch (error) {
    console.error('WebSocket 初始化失败:', error)
    messages.value.push('⚠️ WebSocket 初始化失败')
  }
})

onBeforeUnmount(() => {
  socket?.close()
})

const sendMessage = () => {
  if (!isConnected.value) {
    messages.value.push('⚠️ 发送失败,WebSocket 未连接')
    return
  }
  if (socket && socket.readyState === WebSocket.OPEN && messageInput.value.trim() !== '') {
/*     socket.send(JSON.stringify({
  type: 'chat',
  content: messageInput.value,
  userId: currentUserId
})) */
    socket.send(messageInput.value)
    messages.value.push('发送: ' + messageInput.value)
    messageInput.value = ''
  }
}
</script>

<style scoped>
.websocket-chat input {
  width: 300px;
}
</style>

server.js文件

复制代码
server.js
// server.js (ES Module)
import { WebSocketServer } from 'ws'

// 创建 WebSocket 服务器,监听 8888
const wss = new WebSocketServer({ port: 8888 }, () => {
  console.log('WebSocket 服务器已启动,端口 8888')
})

wss.on('connection', (ws) => {
  console.log('客户端已连接')
  ws.send('欢迎连接本地 WebSocket 服务器!')

  ws.on('message', (message) => {
    console.log('收到客户端消息:', message)

    // 广播给所有客户端
    wss.clients.forEach((client) => {
      if (client.readyState === ws.OPEN) {
        client.send(`广播: ${message}`)
      }
    })
  })

  ws.on('close', () => {
    console.log('客户端断开连接')
  })

  ws.on('error', (err) => {
    console.error('WebSocket 错误:', err)
  })
})
相关推荐
掘金一周6 分钟前
你们觉得房贷多少,没有压力 | 沸点周刊 4.30
前端·人工智能·后端
小小码农Come on8 分钟前
QML访问子项内容
前端·javascript·html
han_27 分钟前
一篇看懂国内外主流大模型:GPT、Claude、Gemini、DeepSeek、通义千问有什么区别?
前端·人工智能·llm
一行代码一行诗++36 分钟前
注释是什么和注释该怎么写(C语言)
java·前端·javascript
涂兵兵_青石疏影42 分钟前
beginPath-vs-save详解
前端
刘马想放假1 小时前
GRE 隧道深度解析:从协议原理到生产实践
网络协议·安全
泽_浪里白条1 小时前
我在 Superset 6.x 做自定义图表 + Embedded SDK 集成的实战复盘(附踩坑清单)
前端·数据可视化
@CLoudbays_Martin111 小时前
UniApp是否能够接入SDK游戏盾呢?
服务器·网络·网络协议·tcp/ip·安全
幽络源小助理1 小时前
小六壬排盘工具源码 自适应双端 纯原生HTML+JS
前端·javascript·html
AIwenIPgeolocation1 小时前
IP地址数据服务:驱动电子商务精细化运营与智能风控
大数据·网络协议·tcp/ip