Rumah hujung hadapan web tutorial css Mula menggunakan websocket html5 hari ini dengan pelayan php

Mula menggunakan websocket html5 hari ini dengan pelayan php

Feb 27, 2025 am 10:24 AM

Start Using HTML5 WebSockets Today With a PHP Server

Memahami WebSockets

WebSocket menetapkan saluran komunikasi yang berterusan, dua hala antara pelanggan (seperti penyemak imbas) dan perkhidmatan backend. Tidak seperti sifat permintaan/tindak balas HTTP, WebSockets menyokong pelbagai protokol dan membolehkan penghantaran mesej pelayan-ke-klien tanpa pengundian yang berterusan.

Apa yang menggantikan WebSockets

WebSockets mengatasi batasan komunikasi HTTP tradisional. Sebelum WebSockets, ketetapan HTTP membuat komunikasi masa nyata mencabar, kerana pelayan tidak dapat secara proaktif menolak data kepada pelanggan.

WebSockets juga menawarkan kelebihan ke atas teknik yang lebih lama seperti Ajax Long Polling dan Server-Sent Events (SSE). Pengundian panjang, sambil mengurangkan latensi dengan mengekalkan sambungan terbuka, masih mengalami masa tamat yang berpotensi. Ini, bersama-sama dengan ketidakcekapan sumber banyak aplikasi Ajax, menyoroti keperluan untuk penyelesaian masa nyata yang lebih cekap-WebSockets. Mereka membolehkan teknologi "push" pelayan, menghantar data kepada pelanggan tanpa memerlukan permintaan sambungan yang telah ditetapkan.

Memasang Perpustakaan WebSockets Ratchet

Ratchet adalah perpustakaan PHP untuk membina aplikasi masa nyata, bi-arah, yang didorong oleh acara menggunakan WebSockets. Kami akan menggunakannya untuk membuat pelayan kami.

Mengandaikan komposer dipasang, gunakan arahan ini:

ini menghasilkan fail
composer require cboden/ratchet
Salin selepas log masuk
yang serupa dengan ini:

composer.json

{
    "require": {
        "cboden/ratchet": "^0.4.4"
    }
}
Salin selepas log masuk
Mewujudkan pelayan websockets

Buat

dengan kod berikut:

server.php

Kod ini mentakrifkan kelas yang melaksanakan
<?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();
Salin selepas log masuk
, mengendalikan sambungan (

), mesej (WebSocketsServer), pemotongan (MessageComponentInterface), dan ralat (onOpen) peristiwa. Kaedah onMessage memulakan pelayan pada port 8089. (Nota: Tutorial hilang kod klien, yang diperlukan untuk melengkapkan contoh.) onClose

Atas ialah kandungan terperinci Mula menggunakan websocket html5 hari ini dengan pelayan php. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Vue 3 Vue 3 Apr 02, 2025 pm 06:32 PM

Ia &#039; s! Tahniah kepada pasukan Vue untuk menyelesaikannya, saya tahu ia adalah usaha besar dan lama datang. Semua dokumen baru juga.

Sedikit di CI/CD Sedikit di CI/CD Apr 02, 2025 pm 06:21 PM

Saya &#039;

Bolehkah anda mendapatkan nilai harta CSS yang sah dari penyemak imbas? Bolehkah anda mendapatkan nilai harta CSS yang sah dari penyemak imbas? Apr 02, 2025 pm 06:17 PM

Saya mempunyai seseorang yang menulis dengan soalan yang sangat legit ini. Lea hanya blog tentang bagaimana anda boleh mendapatkan sifat CSS yang sah dari penyemak imbas. That &#039; s seperti ini.

Kad yang disusun dengan kedudukan melekit dan sasaran sass Kad yang disusun dengan kedudukan melekit dan sasaran sass Apr 03, 2025 am 10:30 AM

Pada hari yang lain, saya melihat sedikit ini sangat indah dari laman web Corey Ginnivan di mana koleksi kad timbunan di atas satu sama lain semasa anda menatal.

Menggunakan Markdown dan Penyetempatan di Editor Blok WordPress Menggunakan Markdown dan Penyetempatan di Editor Blok WordPress Apr 02, 2025 am 04:27 AM

Jika kita perlu menunjukkan dokumentasi kepada pengguna secara langsung dalam editor WordPress, apakah cara terbaik untuk melakukannya?

Membandingkan penyemak imbas untuk reka bentuk responsif Membandingkan penyemak imbas untuk reka bentuk responsif Apr 02, 2025 pm 06:25 PM

Terdapat beberapa aplikasi desktop ini di mana matlamat menunjukkan laman web anda pada dimensi yang berbeza pada masa yang sama. Oleh itu, anda boleh menulis

Kenapa kawasan -kawasan yang dikurangkan ungu di susun atur flex tersilap dianggap sebagai 'ruang limpahan'? Kenapa kawasan -kawasan yang dikurangkan ungu di susun atur flex tersilap dianggap sebagai 'ruang limpahan'? Apr 05, 2025 pm 05:51 PM

Soalan mengenai kawasan slash ungu dalam susun atur flex Apabila menggunakan susun atur flex, anda mungkin menghadapi beberapa fenomena yang mengelirukan, seperti dalam alat pemaju (D ...

Cara menggunakan grid CSS untuk tajuk dan kaki melekit Cara menggunakan grid CSS untuk tajuk dan kaki melekit Apr 02, 2025 pm 06:29 PM

CSS Grid adalah koleksi sifat yang direka untuk menjadikan susun atur lebih mudah daripada yang pernah berlaku. Seperti apa -apa, ada sedikit keluk pembelajaran, tetapi grid adalah

See all articles