使用WebSocket开发网页聊天示例
2024-08-10
37
使用 WebSocket 开发网页聊天示例,需要以下几个步骤:
在服务端创建 WebSocket 服务器。 在客户端创建 WebSocket 连接。 在客户端发送和接收消息。服务端
在服务端创建 WebSocket 服务器,需要使用 WebSocket 相关的 API 来建立 WebSocket 连接。以下是使用 Node.js 创建 WebSocket 服务器的示例:
const http = require("http");
const ws = require("ws");
const server = http.createServer((req, res) => {
if (req.url === "/ws") {
const wss = new ws(req);
wss.on("message", (message) => {
// 接收消息
console.log(message);
// 发送消息
wss.send(message);
});
}
res.writeHead(200, { "Content-Type": "text/plain" });
res.end("Hello, World!");
});
server.listen(8080);
客户端
在客户端创建 WebSocket 连接,需要使用 WebSocket 相关的 API 来建立 WebSocket 连接。以下是使用 JavaScript 创建 WebSocket 连接的示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Websocket Chat</title>
</head>
<body>
<input type="text" id="message">
<button onclick="send()">发送</button>
<ul id="messages"></ul>
<script src="https://cdnjs.cloudflare.com/ajax/libs/socket.io/4.5.0/socket.io.min.js"></script>
<script>
const socket = io("ws://localhost:8080");
socket.on("message", (message) => {
// 接收消息
const li = document.createElement("li");
li.textContent = message;
document.getElementById("messages").appendChild(li);
});
function send() {
// 发送消息
socket.emit("message", document.getElementById("message").value);
}
</script>
</body>
</html>
示例说明
在服务端,我们使用 ws() 函数来创建一个 WebSocket 服务器。服务器会监听 /ws 路径上的 HTTP 请求。当客户端发起 HTTP 请求时,服务器会创建一个新的 WebSocket 连接。
在客户端,我们使用 io() 函数来创建一个 WebSocket 连接。连接成功后,我们会订阅 message 事件,以便接收服务端发送的消息。我们还可以使用 emit() 函数来发送消息给服务端。
更新于:3个月前赞一波!2
相关文章
- 利用python对websocket进行并发压测
- WebSocketException (0x80004005): The remote party closed the WebSocket connection without completing the close handshake
- 实时通信协议SSE和WebSocket对比
- C# WebSocket Client在linux连接失败
- WebSocket实现即时通信 前后端代码示例
- 为什么Web不采用WebSocket进行数据交互
- java的服务端websocket怎么写
- 使用Python进行WebSocket连接:实现实时通信
- Python 异步多路复用 WebSocket:构建高效实时应用
- Python WebSocket 消息实时接收:构建持续通信的实时应用
- 远程物联网连接:TCP与WebSocket的选择考量
- WebSocket和EventSource的区别
文章评论
评论问答