HTML5 WebSockets revolutionize server communication by eliminating the need for AJAX requests. This tutorial guides you through creating a PHP WebSocket server and a client to exchange messages using the WebSocket protocol. A companion post covers using WebSockets with Node.js servers.
Understanding WebSockets
A WebSocket establishes a persistent, two-way communication channel between a client (like a browser) and a backend service. Unlike the request/response nature of HTTP, WebSockets support various protocols and enable server-to-client message delivery without constant polling.
What WebSockets Replace
WebSockets overcome the limitations of traditional HTTP communication. Prior to WebSockets, HTTP's statelessness made real-time communication challenging, as servers couldn't proactively push data to clients.
WebSockets also offer advantages over older techniques like AJAX long polling and Server-Sent Events (SSE). Long polling, while reducing latency by keeping connections open, still suffers from potential timeouts. This, along with the resource inefficiencies of many AJAX applications, highlights the need for a more efficient real-time solution – WebSockets. They enable server-side "push" technology, sending data to clients without needing a pre-established connection request.
Installing the Ratchet WebSockets Library
Ratchet is a PHP library for building real-time, bi-directional, event-driven applications using WebSockets. We'll use it to create our server.
Assuming Composer is installed, use this command:
composer require cboden/ratchet
This generates a composer.json
file similar to this:
{ "require": { "cboden/ratchet": "^0.4.4" } }
Creating the WebSockets Server
Create server.php
with the following code:
<?php use Ratchet\MessageComponentInterface; use Ratchet\ConnectionInterface; use Ratchet\Server\IoServer; use Ratchet\Http\HttpServer; use Ratchet\WebSocket\WsServer; require __DIR__ . '/vendor/autoload.php'; class WebSocketsServer 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) { foreach ($this->clients as $client) { if ($from !== $client) { $client->send($msg); } } } 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 has occurred: {$e->getMessage()}\n"; $conn->close(); } } $server = IoServer::factory( new HttpServer( new WsServer( new WebSocketsServer() ) ), 8089 ); $server->run();
This code defines a WebSocketsServer
class implementing MessageComponentInterface
, handling connection (onOpen
), message (onMessage
), disconnection (onClose
), and error (onError
) events. The run()
method starts the server on port 8089. (Note: The tutorial is missing the client-side code, which would be needed to complete the example.)
The above is the detailed content of Start Using HTML5 WebSockets Today With a PHP Server. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

There are three ways to selectively include CSS on a specific page: 1. Inline CSS, suitable for pages that are not frequently accessed or require unique styles; 2. Load external CSS files using JavaScript conditions, suitable for situations where flexibility is required; 3. Containment on the server side, suitable for scenarios using server-side languages. This approach can optimize website performance and maintainability, but requires balance of modularity and performance.

Flexboxisidealforone-dimensionallayouts,whileGridsuitstwo-dimensional,complexlayouts.UseFlexboxforaligningitemsinasingleaxisandGridforprecisecontroloverrowsandcolumnsinintricatedesigns.

The HTML popover attribute transforms elements into top-layer elements that can be opened and closed with a button or JavaScript. Popovers can be dismissed a number of ways, but there is no option to auto-close them. Preethi has a technique you can u

CSS blocks page rendering because browsers view inline and external CSS as key resources by default, especially with imported stylesheets, header large amounts of inline CSS, and unoptimized media query styles. 1. Extract critical CSS and embed it into HTML; 2. Delay loading non-critical CSS through JavaScript; 3. Use media attributes to optimize loading such as print styles; 4. Compress and merge CSS to reduce requests. It is recommended to use tools to extract key CSS, combine rel="preload" asynchronous loading, and use media delayed loading reasonably to avoid excessive splitting and complex script control.

In the following tutorial, I will show you how to create Lottie animations in Figma. We'll use two colorful designs to exmplify how you can animate in Figma, and then I'll show you how to go from Figma to Lottie animations. All you need is a free Fig

We put it to the test and it turns out Sass can replace JavaScript, at least when it comes to low-level logic and puzzle behavior. With nothing but maps, mixins, functions, and a whole lot of math, we managed to bring our Tangram puzzle to life, no J

ThebestapproachforCSSdependsontheproject'sspecificneeds.Forlargerprojects,externalCSSisbetterduetomaintainabilityandreusability;forsmallerprojectsorsingle-pageapplications,internalCSSmightbemoresuitable.It'scrucialtobalanceprojectsize,performanceneed

No,CSSdoesnothavetobeinlowercase.However,usinglowercaseisrecommendedfor:1)Consistencyandreadability,2)Avoidingerrorsinrelatedtechnologies,3)Potentialperformancebenefits,and4)Improvedcollaborationwithinteams.
