引言
HTML5 WebSocket 是一种在单个 TCP 连接上进行全双工通讯的协议。它允许服务器和客户端之间进行实时数据交换,而不需要轮询或长轮询。WebSocket 在网页应用中有着广泛的应用,如在线游戏、实时聊天、股票交易等。本文将通过实战案例,带你轻松入门和实践 HTML5 WebSocket。
一、WebSocket 基础知识
1.1 WebSocket 协议
WebSocket 协议是基于 TCP 的应用层协议,它允许在单个 TCP 连接上进行全双工通信。WebSocket 协议的连接过程如下:
- 握手:客户端向服务器发送一个特殊的 HTTP 请求,请求升级到 WebSocket 协议。
- 服务器响应:服务器接收到客户端的请求后,如果支持 WebSocket,则返回一个特殊的 HTTP 响应,同意升级连接。
- 建立 WebSocket 连接:客户端和服务器通过握手建立 WebSocket 连接。
1.2 WebSocket API
WebSocket API 提供了以下方法:
WebSocket:创建 WebSocket 连接。open:连接打开时触发。message:接收到消息时触发。close:连接关闭时触发。error:发生错误时触发。
二、实战案例:实时聊天室
2.1 案例背景
本案例将实现一个简单的实时聊天室,用户可以在聊天室中发送和接收消息。
2.2 技术选型
- 前端:HTML5、CSS3、JavaScript
- 后端:Node.js、Express、WebSocket
2.3 实现步骤
- 创建项目:使用 Node.js 和 Express 创建一个简单的 Web 服务器。
- 搭建 WebSocket 服务器:使用
ws模块搭建 WebSocket 服务器。 - 前端页面:使用 HTML5 和 CSS3 创建聊天室页面,并使用 JavaScript 与 WebSocket 服务器进行通信。
2.4 代码示例
WebSocket 服务器:
const WebSocket = require('ws');
const express = require('express');
const http = require('http');
const app = express();
const server = http.createServer(app);
const wss = new WebSocket.Server({ server });
wss.on('connection', function connection(ws) {
ws.on('message', function incoming(message) {
console.log('received: %s', message);
});
ws.send('something');
});
server.listen(8080, () => {
console.log('Server is running on http://localhost:8080');
});
前端页面:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Chat Room</title>
<style>
#chat {
width: 300px;
height: 300px;
border: 1px solid #ccc;
margin: 20px;
padding: 10px;
}
</style>
</head>
<body>
<div id="chat"></div>
<input type="text" id="message" placeholder="Enter message...">
<button onclick="sendMessage()">Send</button>
<script>
const ws = new WebSocket('ws://localhost:8080');
ws.onmessage = function(event) {
const chat = document.getElementById('chat');
chat.innerHTML += `<p>${event.data}</p>`;
};
function sendMessage() {
const message = document.getElementById('message').value;
ws.send(message);
document.getElementById('message').value = '';
}
</script>
</body>
</html>
三、总结
通过本文的实战案例,相信你已经对 HTML5 WebSocket 有了一定的了解。在实际开发中,WebSocket 可以应用于各种实时应用场景,如在线游戏、实时聊天、股票交易等。希望本文能帮助你轻松入门和实践 HTML5 WebSocket。
