ws 協定

目前 Workerman 的ws 協定版本為 13

Workerman 可以作為客戶端,透過 ws 協定發起 websocket 連線,連接到遠端 websocket 伺服器,實現雙向通訊。

注意
ws 協定只能透過 AsyncTcpConnection 作為客戶端使用,不能作為 websocket 伺服器監聽協定。也就是說以下寫法是錯誤的。

$worker = new Worker('ws://0.0.0.0:8080');

如果想用 Workerman 作為 websocket 伺服器,請使用websocket 協定

ws 作為 websocket 客戶端協定範例:

<?php
require_once __DIR__ . '/vendor/autoload.php';

use Workerman\Protocols\Ws;
use Workerman\Worker;
use Workerman\Connection\AsyncTcpConnection;

$worker = new Worker();
// 程序啟動時
$worker->onWorkerStart = function()
{
    // 以 websocket 協定連接遠端 websocket 伺服器
    $ws_connection = new AsyncTcpConnection("ws://127.0.0.1:1234");
    // 每隔 55 秒向伺服器發送一個 opcode 為 0x9 的 websocket 心跳(可選)
    $ws_connection->websocketPingInterval = 55;
    // 設置 http 頭(可選)
    $ws_connection->headers = [
        'Cookie' => 'PHPSID=82u98fjhakfusuanfnahfi; token=2hf9a929jhfihaf9i',
        'OtherKey' => 'values'
    ];
    // 設置數據類型(可選)
    $ws_connection->websocketType = Ws::BINARY_TYPE_BLOB; // BINARY_TYPE_BLOB 為文本 BINARY_TYPE_ARRAYBUFFER 為二進制
    // 當 TCP 完成三次握手後(可選)
    $ws_connection->onConnect = function($connection){
        echo "tcp connected\n";
    };
    // 當 websocket 完成握手後(可選)
    $ws_connection->onWebSocketConnect = function(AsyncTcpConnection $con, $response) {
        echo $response;
        $con->send('hello');
    };
    // 當遠端 websocket 伺服器發來消息時
    $ws_connection->onMessage = function($connection, $data){
        echo "recv: $data\n";
    };
    // 連接上發生錯誤時,一般是連接遠端 websocket 伺服器失敗的錯誤(可選)
    $ws_connection->onError = function($connection, $code, $msg){
        echo "error: $msg\n";
    };
    // 當連接遠端 websocket 伺服器的連接斷開時(可選,建議加上重連)
    $ws_connection->onClose = function($connection){
        echo "connection closed and try to reconnect\n";
        // 如果連接斷開,1 秒後重連
        $connection->reConnect(1);
    };
    // 設置好以上各種回調後,執行連接操作
    $ws_connection->connect();
};
Worker::runAll();

更多參考作為 ws/wss 客戶端