Mula menggunakan websocket html5 hari ini dengan pelayan php
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.
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.
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:
Buat
), mesej (
composer require cboden/ratchet
composer.json
{
"require": {
"cboden/ratchet": "^0.4.4"
}
}
server.php
<?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();
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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

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

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

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

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 ' s seperti ini.

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.

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

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

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 ...

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
