swoole 第六課 WebSocket 服務(wù)器

WebSocket 服務(wù)器

程序代碼

ws_server.php

//創(chuàng)建websocket服務(wù)器對(duì)象,監(jiān)聽0.0.0.0:9502端口
$ws = new Swoole\WebSocket\Server("0.0.0.0", 9502);

//監(jiān)聽WebSocket連接打開事件
$ws->on('open', function ($ws, $request) {
    var_dump($request->fd, $request->get, $request->server);
    $ws->push($request->fd, "hello, welcome\n");
});

//監(jiān)聽WebSocket消息事件
$ws->on('message', function ($ws, $frame) {
    echo "Message: {$frame->data}\n";
    $ws->push($frame->fd, "server: {$frame->data}");
});

//監(jiān)聽WebSocket連接關(guān)閉事件
$ws->on('close', function ($ws, $fd) {
    echo "client-{$fd} is closed\n";
});

$ws->start();
  • 客戶端向服務(wù)器端發(fā)送信息時(shí),服務(wù)器端觸發(fā) onMessage 事件回調(diào)
  • 服務(wù)器端可以調(diào)用 $server->push() 向某個(gè)客戶端(使用 $fd 標(biāo)識(shí)符)發(fā)送消息

運(yùn)行程序

php ws_server.php

可以使用 Chrome 瀏覽器進(jìn)行測(cè)試,JS 代碼為:

var wsServer = 'ws://127.0.0.1:9502';
var websocket = new WebSocket(wsServer);
websocket.onopen = function (evt) {
    console.log("Connected to WebSocket server.");
};

websocket.onclose = function (evt) {
    console.log("Disconnected");
};

websocket.onmessage = function (evt) {
    console.log('Retrieved data from server: ' + evt.data);
};

websocket.onerror = function (evt, e) {
    console.log('Error occured: ' + evt.data);
};

Comet

WebSocket 服務(wù)器除了提供 WebSocket 功能之外,實(shí)際上也可以處理 Http 長連接。只需要增加 onRequest 事件監(jiān)聽即可實(shí)現(xiàn) Comet 方案 Http 長輪詢。

詳細(xì)使用方法參考 Swoole\Websocket

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容