티스토리 뷰





반응형

VueUse 설치

npm i -D @vueuse/nuxt @vueuse/core

nuxt.config.ts 설정

export default defineNuxtConfig({
  modules: ['@vueuse/nuxt'],
  nitro: {
    experimental: {
      websocket: true
    }
  }
})

 

다양한 기능을 제공하는 vueUse를 설치하고 config 설치까지 해줍시다.

웹소켓과 관련한 설정은 nuxt.config.ts에서 true로만 바꿔주면 되니 아주 간단하네요!

WebSokcet 서버구성

server/api/websocket.ts 

const room = 'ROOM'

export default defineWebSocketHandler({
    open(peer) {
        console.log("[ws] open", peer);
        peer.subscribe(room)
        peer.publish(room, 'Another user joined the chat')
    },

    close(peer) {
        console.log("[ws] close", peer);
    },

    error(peer, error) {
        console.log("[ws] error", peer, error);
    },

    message(peer, message) {
        console.log('[ws] message', peer, message)
        peer.publish(room, message.text())
    }
});

Client 구성

가볍게 index.vue에서 테스트를 진행해봅시다.

<script setup lang="ts">

import { useWebSocket } from '@vueuse/core'

const localUrl = 'ws://localhost:3000/api/websocket';
const { status, data, send, open, close } = useWebSocket(localUrl)

const message = ref('')
const history = ref<string[]>([])

watch(data, (receiveMsg: string) => {
  history.value.push(`server: ${receiveMsg}`)
})

function sendMessage() {
  if (message.value == null || message.value === '') {
    return false
  }

  history.value.push(`client : ${message.value}`)
  send(message.value);
  message.value = '';
}

</script>

<template>
  <div>
    <h1>WebSocket - let's go</h1>
    <form @submit.prevent="sendMessage">
      <input v-model="message"/>
      <button type="submit">Send</button>
    </form>
    <div>
      <p v-for="entry in history">{{ entry }}</p>
    </div>
  </div>
</template>


<style scoped>

</style>

테스트

 

브라우저 2개를 띄워서 테스트가 가능한데, 실시간으로 통신이 가능한 것을 확인 할 수 있다.

 

출처: https://www.youtube.com/watch?v=OfY7JcrqkPg&t=721s

반응형
댓글
반응형
최근에 달린 댓글
글 보관함
Total
Today
Yesterday
최근에 올라온 글
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31