Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk melaksanakan fungsi pemesejan segera dalam pembangunan fungsi back-end PHP?

Bagaimana untuk melaksanakan fungsi pemesejan segera dalam pembangunan fungsi back-end PHP?

WBOY
WBOYasal
2023-08-08 09:25:051510semak imbas

Bagaimana untuk melaksanakan fungsi pemesejan segera dalam pembangunan fungsi back-end PHP?

Bagaimana untuk melaksanakan fungsi pemesejan segera dalam pembangunan fungsi back-end PHP?

Kata Pengantar:
Dengan perkembangan pesat Internet mudah alih, pemesejan segera telah menjadi cara penting untuk orang ramai berkomunikasi dalam kehidupan seharian. Bagaimana untuk melaksanakan fungsi pemesejan segera dalam pembangunan fungsi back-end PHP? Artikel ini akan memperkenalkan kaedah pelaksanaan berdasarkan WebSocket dan PHP, dan memberikan contoh kod yang sepadan.

1. Pengenalan kepada WebSocket
WebSocket ialah protokol untuk komunikasi dupleks penuh pada satu sambungan TCP. Berbanding dengan protokol HTTP tradisional, WebSocket mempunyai ciri prestasi masa nyata yang baik, prestasi tinggi dan kependaman rendah, dan sangat sesuai untuk melaksanakan fungsi pemesejan segera.

2. Pembinaan persekitaran pelayan

  1. Pasang perpustakaan WebSocket
    Dalam pembangunan PHP, kita boleh menggunakan perpustakaan Ratchet untuk melaksanakan fungsi WebSocket. Pustaka Ratchet boleh dipasang melalui Composer Arahan pemasangan khusus adalah seperti berikut:

    composer require cboden/ratchet
  2. Buat pelayan WebSocket
    Kami boleh mencipta fail server.php sebagai pelayan WebSocket adalah seperti berikut: server.php文件作为WebSocket服务器,具体代码如下所示:

    <?php
    require 'vendor/autoload.php';
    
    use RatchetConnectionInterface;
    use RatchetMessageComponentInterface;
    use RatchetServerIoServer;
    use RatchetHttpHttpServer;
    use RatchetWebSocketWsServer;
    
    class Chat implements MessageComponentInterface {
        protected $clients;
    
        public function __construct() {
            $this->clients = new SplObjectStorage;
        }
    
        public function onOpen(ConnectionInterface $conn) {
            $this->clients->attach($conn);
            echo "New client connected: {$conn->resourceId}
    ";
        }
    
        public function onMessage(ConnectionInterface $from, $msg) {
            echo "Received message from {$from->resourceId}: {$msg}
    ";
            // 在这里可以对消息进行处理,如保存到数据库、发送给其他连接等
        }
    
        public function onClose(ConnectionInterface $conn) {
            $this->clients->detach($conn);
            echo "Client disconnected: {$conn->resourceId}
    ";
        }
    
        public function onError(ConnectionInterface $conn, Exception $e) {
            echo "An error occurred: {$e->getMessage()}
    ";
            $conn->close();
        }
    }
    
    $server = IoServer::factory(
        new HttpServer(
            new WsServer(
                new Chat()
            )
        ),
        8080
    );
    $server->run();

    这段代码创建了一个Chat类,实现了MessageComponentInterface接口。在onOpen方法中,我们将新连接添加到clients列表中,并输出连接的资源ID;在onMessage方法中,我们可以对接收到的消息进行处理,比如保存到数据库、发送给其他连接等;在onClose方法中,我们从clients列表中移除断开的连接,并输出断开的资源ID;在onError方法中,我们可以对错误进行处理。最后,我们使用IoServer创建WebSocket服务器,并监听8080端口。

三、客户端实现
我们可以使用HTML和JavaScript来实现WebSocket的客户端功能。以下是一个简单的示例:

<!DOCTYPE html>
<html>
<head>
    <title>WebSocket Test</title>
</head>
<body>
    <div id="message-container"></div>
    <input type="text" id="message-input">
    <button onclick="sendMessage()">Send</button>
    
    <script>
        var websocket = new WebSocket('ws://localhost:8080');
        
        websocket.onopen = function(event) {
            console.log('WebSocket connected');
        };
        
        websocket.onmessage = function(event) {
            var messageContainer = document.getElementById('message-container');
            var newMessage = document.createElement('div');
            newMessage.innerHTML = event.data;
            messageContainer.appendChild(newMessage);
        };
        
        function sendMessage() {
            var messageInput = document.getElementById('message-input');
            var message = messageInput.value;
            websocket.send(message);
            messageInput.value = '';
        }
    </script>
</body>
</html>

这段代码创建了一个WebSocket对象,并指定连接到ws://localhost:8080,即前面创建的服务器。在onopen事件中,我们可以进行一些初始化操作;在onmessage事件中,我们可以处理从服务器接收到的消息,并添加到页面上;在sendMessage

php server.php

Kod ini mencipta kelas Sembang yang melaksanakan antara muka MessageComponentInterface. Dalam kaedah onOpen, kami menambah sambungan baharu pada senarai clients dan mengeluarkan ID sumber sambungan dalam kaedah onMessage, kami boleh Memproses mesej yang diterima, seperti menyimpan ke pangkalan data, menghantar ke sambungan lain, dsb. dalam kaedah onClose, kami mengalih keluar sambungan yang terputus daripada senarai clients, Dan keluarkan ID sumber terputus dalam kaedah onError, kami boleh menangani ralat itu. Akhir sekali, kami menggunakan IoServer untuk mencipta pelayan WebSocket dan mendengar port 8080.

  1. 3. Pelaksanaan pelanggan

    Kami boleh menggunakan HTML dan JavaScript untuk melaksanakan fungsi klien WebSocket. Berikut ialah contoh mudah:
    rrreee

    Kod ini mencipta objek WebSocket dan menentukan sambungan ke ws://localhost:8080, pelayan yang dibuat lebih awal. Dalam acara onopen, kami boleh melakukan beberapa operasi pemulaan dalam acara onmessage, kami boleh memproses mesej yang diterima daripada pelayan dan menambahnya pada halaman onmessage, kita boleh Dalam fungsi >sendMessage, kita boleh menghantar mesej ke pelayan. Terdapat kotak input dan butang pada halaman yang boleh digunakan untuk memasukkan dan menghantar mesej.

    4. Jalankan dan uji

  2. Mulakan pelayan WebSocket
Tukar ke direktori projek pada baris arahan dan laksanakan arahan berikut untuk memulakan pelayan WebSocket:

rrreee
Pada masa ini, pelayan telah berjaya dimulakan dan boleh menerima dan menghantar mesej.

🎜🎜Buka halaman klien🎜Buka halaman klien yang dibuat lebih awal dalam penyemak imbas, anda boleh melihat kotak input dan butang. Masukkan mesej dalam kotak input dan klik butang untuk menghantar. Pelayan akan menerima mesej dan menyiarkannya kepada semua pelanggan yang disambungkan, dan halaman klien akan memaparkan mesej yang diterima. 🎜🎜🎜Kesimpulan: 🎜Melalui langkah di atas, kami berjaya melaksanakan fungsi pemesejan segera menggunakan WebSocket dalam pembangunan back-end PHP. WebSocket boleh merealisasikan penghantaran mesej masa nyata dan cekap dan sesuai untuk pembangunan pelbagai aplikasi pemesejan segera. Saya harap artikel ini dapat membantu semua orang. 🎜

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan fungsi pemesejan segera dalam pembangunan fungsi back-end PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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