dcnl1980 / ratchet
PHP WebSocket 库
v0.5.1
2021-10-01 09:48 UTC
Requires
- php: >=5.4.2 || ^7 || ^8
- dcnl1980/rfc6455: ^0.3
- guzzlehttp/psr7: ^1.5 || ^2.0
- react/socket: ^1.0 || ^0.8 || ^0.7 || ^0.6 || ^0.5
- symfony/http-foundation: ^2.6|^3.0|^4.0|^5.0
- symfony/routing: ^2.6|^3.0|^4.0|^5.0
Requires (Dev)
- phpunit/phpunit: ~4.8
This package is auto-updated.
Last update: 2024-09-29 05:49:13 UTC
README
一个用于异步服务 WebSockets 的 PHP 库。通过简单的接口构建您的应用程序,并通过组合不同的组件来重用您的应用程序,而无需更改任何代码。
要求
需要 Shell 访问,建议具有 root 访问权限。为了避免代理/防火墙阻塞,建议在端口 80 或 443(SSL)上请求 WebSocket,这需要 root 访问权限。为了做到这一点,您可以使用反向代理或两台独立的机器,以及您的同步 Web 栈。您可以在服务器配置文档中找到更多详细信息。
文档
用户和 API 文档可在 Ratchet 网站上找到: http://socketo.me
请参阅https://github.com/cboden/Ratchet-examples,了解使用 Ratchet 的一些现成工作演示。
需要帮助?有什么问题?想提供反馈?请在Google Groups 邮件列表上发消息。
快速示例
<?php use Ratchet\MessageComponentInterface; use Ratchet\ConnectionInterface; // Make sure composer dependencies have been installed require __DIR__ . '/vendor/autoload.php'; /** * chat.php * Send any incoming messages to all connected clients (except sender) */ class MyChat implements MessageComponentInterface { protected $clients; public function __construct() { $this->clients = new \SplObjectStorage; } public function onOpen(ConnectionInterface $conn) { $this->clients->attach($conn); } public function onMessage(ConnectionInterface $from, $msg) { foreach ($this->clients as $client) { if ($from != $client) { $client->send($msg); } } } public function onClose(ConnectionInterface $conn) { $this->clients->detach($conn); } public function onError(ConnectionInterface $conn, \Exception $e) { $conn->close(); } } // Run the server application through the WebSocket protocol on port 8080 $app = new Ratchet\App('localhost', 8080); $app->route('/chat', new MyChat, array('*')); $app->route('/echo', new Ratchet\Server\EchoServer, array('*')); $app->run();
$ php chat.php
// Then some JavaScript in the browser: var conn = new WebSocket('ws://:8080/echo'); conn.onmessage = function(e) { console.log(e.data); }; conn.onopen = function(e) { conn.send('Hello Me!'); };