1. 选择WebSocket库: PHP本身没有原生支持WebSocket,所以你需要使用第三方WebSocket库。常用的选择是Ratchet(https://github.com/ratchetphp/Ratchet)。你可以通过Composer来安装它。
2. 设置WebSocket服务器: 在你的PHP项目中,创建一个WebSocket服务器脚本。这个脚本将会监听WebSocket连接并处理客户端的消息。
3. 处理连接与断开:当客户端连接到WebSocket服务器时,你需要跟踪连接的用户,并在用户断开连接时进行处理。
4. 实现广播: 要给所有连接的用户推送消息,你可以创建一个广播功能,将消息发送到所有已连接的客户端。
5. 实现点对点推送:要给指定连接的用户推送消息,你可以通过识别每个连接的唯一标识符来实现点对点推送。
下面是一个简单的示例代码,演示了如何使用Ratchet库来搭建一个WebSocket服务端,实现广播和点对点推送:
<?php
// 1. 使用Composer安装Ratchet库
// composer require cboden/ratchet
// 2. 引入Ratchet库
require 'vendor/autoload.php';
use Ratchet\MessageComponentInterface;
use Ratchet\ConnectionInterface;
// 3. 创建WebSocket服务端类
class MyWebSocketServer implements MessageComponentInterface {
protected $clients;
public function __construct() {
$this->clients = new \SplObjectStorage;
}
public function onOpen(ConnectionInterface $conn) {
// 新连接加入,保存客户端连接
$this->clients->attach($conn);
echo "New connection! ({$conn->resourceId})\n";
}
public function onMessage(ConnectionInterface $from, $msg) {
$data = json_decode($msg, true);
if ($data['type'] === 'broadcast') {
// 广播消息给所有连接的客户端
$this->broadcastMessage($data['message']);
} elseif ($data['type'] === 'private' && isset($data['recipient'])) {
// 发送私有消息给特定客户端
$this->sendPrivateMessage($data['message'], $data['recipient']);
}
}
public function onClose(ConnectionInterface $conn) {
// 连接断开,从客户端连接列表中移除
$this->clients->detach($conn);
echo "Connection {$conn->resourceId} has disconnected\n";
}
public function onError(ConnectionInterface $conn, \Exception $e) {
echo "An error occurred: {$e->getMessage()}\n";
$conn->close();
}
public function broadcastMessage($message) {
foreach ($this->clients as $client) {
$client->send($message);
}
}
public function sendPrivateMessage($message, $recipient) {
foreach ($this->clients as $client) {
if ($client->resourceId == $recipient) {
$client->send($message);
return;
}
}
}
}
// 4. 启动WebSocket服务器
$server = new \Ratchet\App('127.0.0.1', 2347);
$server->route('/websocket', new MyWebSocketServer, ['*']);
echo "WebSocket server is running...\n";
$server->run();运行脚本
php 文件名 start
客户端调用:
<!DOCTYPE html>
<html>
<head>
<title>WebSocket Client</title>
</head>
<body>
<h1>WebSocket Client</h1>
<div id="output"></div>
<script>
const outputDiv = document.getElementById('output');
const webSocket = new WebSocket('ws://127.0.0.1:2347/websocket'); // Replace with your WebSocket server address
webSocket.onopen = () => {
outputDiv.innerHTML += '<p>WebSocket connection is open.</p>';
};
webSocket.onmessage = (event) => {
const message = event.data;
outputDiv.innerHTML += '<p>${message}</p>';
};
webSocket.onclose = () => {
outputDiv.innerHTML += '<p>WebSocket connection is closed.</p>';
};
function sendMessage() {
const message = document.getElementById('messageInput').value;
webSocket.send(JSON.stringify({ type: 'broadcast', message: message }));
}
function sendPrivateMessage() {
const recipientId = document.getElementById('recipientInput').value;
const message = document.getElementById('privateMessageInput').value;
webSocket.send(JSON.stringify({ type: 'private', message: message, recipient: recipientId }));
}
</script>
<h2>Send a Broadcast Message</h2>
<input type="text" id="messageInput" placeholder="Enter message">
<button onclick="sendMessage()">Send Broadcast</button>
<h2>Send a Private Message</h2>
<input type="text" id="recipientInput" placeholder="Recipient ID">
<input type="text" id="privateMessageInput" placeholder="Enter private message">
<button onclick="sendPrivateMessage()">Send Private</button>
</body>
</html>