Maison >interface Web >js tutoriel >WebSockets et Socket.IO : communication en temps réel avec Node.js
La communication en temps réel est essentielle dans les applications modernes telles que les applications de chat, les jeux en ligne et les outils de collaboration en direct. Les WebSockets fournissent un canal de communication full-duplex sur une seule connexion TCP, permettant d'échanger des données entre le client et le serveur en temps réel. Cet article expliquera les WebSockets, leurs cas d'utilisation et comment les implémenter dans Node.js. De plus, nous plongerons dans Socket.IO, une bibliothèque populaire qui simplifie la communication WebSocket, ainsi que des exemples pratiques.
Dans cet article, nous aborderons :
WebSockets fournissent un protocole de communication bidirectionnel qui permet au serveur et au client d'envoyer des données à tout moment. Contrairement à HTTP, où le client initie toutes les communications et demande des données au serveur, les WebSockets permettent des connexions persistantes, permettant aux deux parties d'échanger des données en continu sans rétablir la connexion.
Bien que les deux protocoles fonctionnent sur TCP, ils présentent des différences significatives :
Feature | WebSockets | HTTP |
---|---|---|
Connection | Persistent, full-duplex | Stateless, new connection for each request |
Directionality | Bi-directional (server and client communicate) | Client to server only (server responds) |
Overhead | Low after connection establishment | Higher due to headers with every request |
Use Case | Real-time applications (chats, games) | Traditional websites, API requests |
WebSocket 서버를 생성하기 위해 Node.js는 WebSocket 서버를 생성하고 클라이언트와 통신을 설정할 수 있는 내장 ws 라이브러리를 제공합니다.
npm install ws
const WebSocket = require('ws'); // Create a WebSocket server on port 8080 const wss = new WebSocket.Server({ port: 8080 }); // Listen for incoming connections wss.on('connection', (ws) => { console.log('Client connected'); // Send a message to the client ws.send('Welcome to the WebSocket server!'); // Listen for messages from the client ws.on('message', (message) => { console.log(`Received: ${message}`); ws.send(`Echo: ${message}`); }); // Handle connection closure ws.on('close', () => { console.log('Client disconnected'); }); }); console.log('WebSocket server running on ws://localhost:8080');
이 예에서는:
클라이언트 측에서는 JavaScript를 사용하여 WebSocket 서버에 연결할 수 있습니다.
const socket = new WebSocket('ws://localhost:8080'); // Event listener for when the connection is established socket.addEventListener('open', (event) => { socket.send('Hello Server!'); }); // Listen for messages from the server socket.addEventListener('message', (event) => { console.log(`Message from server: ${event.data}`); });
Socket.IO는 다음을 제공하여 WebSocket 통신을 더 쉽게 만드는 라이브러리입니다.
npm install socket.io
const express = require('express'); const http = require('http'); const socketIo = require('socket.io'); const app = express(); const server = http.createServer(app); const io = socketIo(server); // Listen for incoming connections io.on('connection', (socket) => { console.log('New client connected'); // Listen for messages from the client socket.on('message', (msg) => { console.log(`Message from client: ${msg}`); socket.emit('response', `Server received: ${msg}`); }); // Handle disconnection socket.on('disconnect', () => { console.log('Client disconnected'); }); }); // Start the server server.listen(3000, () => { console.log('Server running on http://localhost:3000'); });
이 코드에서는:
Socket.IO를 사용하여 간단한 실시간 채팅 애플리케이션을 구축하여 그 성능을 입증해 보겠습니다.
const express = require('express'); const http = require('http'); const socketIo = require('socket.io'); const app = express(); const server = http.createServer(app); const io = socketIo(server); app.get('/', (req, res) => { res.sendFile(__dirname + '/index.html'); }); io.on('connection', (socket) => { console.log('A user connected'); // Broadcast when a user sends a message socket.on('chat message', (msg) => { io.emit('chat message', msg); }); socket.on('disconnect', () => { console.log('User disconnected'); }); }); server.listen(3000, () => { console.log('Listening on *:3000'); });
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Socket.IO Chat</title> <script src="/socket.io/socket.io.js"></script> </head> <body> <h1>Real-time Chat</h1> <ul id="messages"></ul> <form id="chatForm"> <input id="message" autocomplete="off" /><button>Send</button> </form> <script> const socket = io(); // Listen for incoming chat messages socket.on('chat message', (msg) => { const li = document.createElement('li'); li.textContent = msg; document.getElementById('messages').appendChild(li); }); // Send chat message const form = document.getElementById('chatForm'); form.addEventListener('submit', (e) => { e.preventDefault(); const message = document.getElementById('message').value; socket.emit('chat message', message); document.getElementById('message').value = ''; }); </script> </body> </html>
이 간단한 채팅 애플리케이션을 사용하면 여러 사용자가 실시간으로 연결하고 메시지를 교환할 수 있습니다. 한 사용자가 보낸 메시지는 서버에 연결된 다른 모든 사용자에게 방송됩니다.
WebSocket과 Socket.IO는 다음을 포함하여 실시간 통신이 필요한 시나리오에 적합합니다.
HTTP와 마찬가지로 WebSocket 연결은 민감한 데이터를 보호하기 위해 보안을 유지해야 합니다. 이는 기본적으로 TLS(전송 계층 보안)를 통한 WebSocket인 wss://(WebSocket Secure)를 사용하여 수행할 수 있습니다.
NGINX 구성 예:
server { listen 443 ssl; server_name yourdomain.com; ssl_certificate /etc/ssl/certs/yourdomain.crt; ssl_certificate_key /etc/ssl/private/yourdomain.key; location / { proxy_pass http://localhost:8080; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "upgrade"; } }
이렇게 하면 모든 WebSocket 트래픽이 암호화되어 도청 및 변조로부터 보호됩니다.
WebSocket과 Socket.IO를 사용하면 클라이언트와 서버 간의 실시간 통신이 가능하며 이는 즉각적인 업데이트가 필요한 최신 애플리케이션에 필수적입니다. WebSocket 또는 Socket.IO 기반 솔루션을 구현하면 채팅 시스템, 협업 도구, 라이브 대시보드와 같은 반응성이 뛰어나고 효율적인 애플리케이션을 구축할 수 있습니다.
이 기사에서는 WebSocket의 기본 사항, Socket.IO 사용의 장점, Node.js에서 실시간 애플리케이션을 만드는 방법을 다루었습니다. 또한 전송 중 데이터 안전을 보장하기 위해 WebSocket 연결을 보호하는 방법을 살펴보았습니다.
이러한 기술을 익히면 강력하고 대화형이며 확장 가능한 웹 애플리케이션을 구축할 수 있는 수많은 가능성이 열립니다.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!