phrity/websocket

WebSocket client and server

Maintainers

๐Ÿ‘ sirn-se

Package info

github.com/sirn-se/websocket-php

Homepage

pkg:composer/phrity/websocket

Statistics

Installs: 4โ€‰781โ€‰128

Dependents: 38

Suggesters: 2

Stars: 216

Open Issues: 1

3.7.2 2026-06-15 08:13 UTC

Requires

Suggests

None

Provides

None

Conflicts

None

Replaces

None

ISC a8edb30395d45edd83452f54dfbb0905c3115a95

websocketclientserver


README

๐Ÿ‘ Phrity Websocket

Websocket Client and Server for PHP

๐Ÿ‘ Build Status

This library contains WebSocket client and server for PHP.

The client and server provides methods for reading and writing to WebSocket streams.

This repo replaces the abandoned textalk/websocket repo and is maintained by Sรถren Jensen, who has been maintaining the original since v1.3.

Some features

  • Client and multi-connection Server
  • ws (TCP) and wss (SSL) support
  • Listener callbacks on incoming messages and other events
  • Close and Ping/Pong handling (standard middlewares)
  • Deflate compression (middleware)
  • Additional optional middlewares and ability to create own middlewares
  • Support message fragmentation and payload masking

Documentation

Migration

  • v1 -> v2 - How to migrate from v1 to v2
  • v2 -> v3 - How to migrate from v2 to v3

Installing

Preferred way to install is with Composer.

composer require phrity/websocket

Client

The client can read and write on a WebSocket stream. It internally supports Upgrade handshake and implicit close and ping/pong operations.

Set up a WebSocket Client for request/response strategy.

$client = new WebSocket\Client("wss://echo.websocket.org/");
$client
 // Add standard middlewares
 ->addMiddleware(new WebSocket\Middleware\CloseHandler())
 ->addMiddleware(new WebSocket\Middleware\PingResponder())
 ;

// Send a message
$client->text("Hello WebSocket.org!");

// Read response (this is blocking)
$message = $client->receive();
echo "Got message: {$message->getContent()}\n";

// Close connection
$client->close();

Set up a WebSocket Client for continuous subscription

$client = new WebSocket\Client("wss://echo.websocket.org/");
$client
 // Add standard middlewares
 ->addMiddleware(new WebSocket\Middleware\CloseHandler())
 ->addMiddleware(new WebSocket\Middleware\PingResponder())
 // Listen to incoming Text messages
 ->onText(function (WebSocket\Client $client, WebSocket\Connection $connection, WebSocket\Message\Message $message) {
 // Act on incoming message
 echo "Got message: {$message->getContent()}\n";
 // Possibly respond to server
 $client->text("I got your your message");
 })
 ->start();

Server

The server is a multi connection, listening server. It internally supports Upgrade handshake and implicit close and ping/pong operations.

Set up a WebSocket Server for continuous listening

$server = new WebSocket\Server();
$server
 // Add standard middlewares
 ->addMiddleware(new WebSocket\Middleware\CloseHandler())
 ->addMiddleware(new WebSocket\Middleware\PingResponder())
 // Listen to incoming Text messages
 ->onText(function (WebSocket\Server $server, WebSocket\Connection $connection, WebSocket\Message\Message $message) {
 // Act on incoming message
 echo "Got message: {$message->getContent()}\n";
 // Possibly respond to client
 $connection->text("I got your your message");
 })
 ->start();

License

ISC License