Aplikacja real-time do czatu jest doskonałym przykładem wykorzystania programu WebSocket do Node.js tworzenia interaktywnych i wciągających doświadczeń użytkownika. W tym artykule przyjrzymy się, jak zbudować real-time aplikację czatu przy użyciu WebSocket i Node.js.
Krok 1: Konfigurowanie środowiska
Najpierw upewnij się, że zainstalowałeś Node.js na swoim komputerze. Utwórz nowy folder dla swojego projektu i przejdź do niego za pomocą Terminal lub Command Prompt.
Krok 2: Instalowanie WebSocket biblioteki
Tak jak poprzednio, użyj biblioteki „ws”, aby zainstalować WebSocket bibliotekę:
npm install ws
Krok 3: Budowa WebSocket serwera
Utwórz plik o nazwie server.js
i napisz następujący kod:
// Import the WebSocket library
const WebSocket = require('ws');
// Create a WebSocket server
const server = new WebSocket.Server({ port: 8080 });
// List of connections(clients)
const clients = new Set();
// Handle new connections
server.on('connection',(socket) => {
console.log('Client connected.');
// Add connection to the list
clients.add(socket);
// Handle incoming messages from the client
socket.on('message',(message) => {
// Send the message to all other connections
for(const client of clients) {
if(client !== socket) {
client.send(message);
}
}
});
// Handle connection close
socket.on('close',() => {
console.log('Client disconnected.');
// Remove the connection from the list
clients.delete(socket);
});
});
Krok 4: Tworzenie interfejsu użytkownika(klient)
Utwórz plik o nazwie index.html
i napisz następujący kod:
<!DOCTYPE html>
<html>
<head>
<title>Real-Time Chat</title>
</head>
<body>
<input type="text" id="message" placeholder="Type a message">
<button onclick="send()">Send</button>
<div id="chat"></div>
<script>
const socket = new WebSocket('ws://localhost:8080');
socket.onmessage =(event) => {
const chat = document.getElementById('chat');
chat.innerHTML += '<p>' + event.data + '</p>';
};
function send() {
const messageInput = document.getElementById('message');
const message = messageInput.value;
socket.send(message);
messageInput.value = '';
}
</script>
</body>
</html>
Krok 5: Uruchomienie serwera i otwarcie przeglądarki
W programie Terminal uruchom następujące polecenie, aby uruchomić WebSocket serwer:
node server.js
Otwórz przeglądarkę internetową i przejdź do „ http://localhost:8080 ”, aby skorzystać z real-time aplikacji czatu.
Wniosek
Gratulacje! Pomyślnie zbudowałeś real-time aplikację czatu przy użyciu WebSocket i Node.js. Ta aplikacja umożliwia użytkownikom interakcję i wysyłanie/odbieranie wiadomości w formacie real-time. Możesz nadal rozszerzać i dostosowywać tę aplikację, aby tworzyć różne ekscytujące funkcje!