# on
(要求Workerman版本>=3.3.0)

void \Channel\Client::on(string $event_name, callback $callback_function)

訂閱$event_name事件並註冊事件發生時的回調$callback_function

回調函數的參數

$event_name

訂閱的事件名稱,可以是任意的字符串。

$callback_function

事件發生時觸發的回調函數。函數原型為callback_function(mixed $event_data)$event_data是事件發布(publish)時傳遞的事件數據。

注意:

如果同一個事件註冊了兩個回調函數,後一個回調函數將覆蓋前一個回調函數。

范例

多進程Worker(多伺服器),一個客戶端發消息,廣播給所有客戶端

start.php

<?php
use Workerman\Worker;
use Workerman\Connection\TcpConnection;
require_once __DIR__ . '/vendor/autoload.php';

// 初始化一個Channel服務端
$channel_server = new Channel\Server('0.0.0.0', 2206);

// websocket服務端
$worker = new Worker('websocket://0.0.0.0:4236');
$worker->name = 'websocket';
$worker->count = 6;
// 每個worker進程啟動時
$worker->onWorkerStart = function($worker)
{
    // Channel客戶端連接到Channel服務端
    Channel\Client::connect('127.0.0.1', 2206);
    // 訂閱broadcast事件,並註冊事件回調
    Channel\Client::on('broadcast', function($event_data)use($worker){
        // 向當前worker進程的所有客戶端廣播消息
        foreach($worker->connections as $connection)
        {
            $connection->send($event_data);
        }
    });
};

$worker->onMessage = function(TcpConnection $connection, $data)
{
   // 將客戶端發來的數據當做事件數據
   $event_data = $data;
   // 向所有worker進程發布broadcast事件
   \Channel\Client::publish('broadcast', $event_data);
};

Worker::runAll();

測試

打開chrome瀏覽器,按F12打開調試控制台,在Console一欄輸入(或者把下面代碼放入到html頁面用js運行)

接收消息的連接

// 127.0.0.1換成實際workerman所在ip
ws = new WebSocket("ws://127.0.0.1:4236");
ws.onmessage = function(e) {
    alert("收到服務端的消息:" + e.data);
};

廣播消息

ws.send('hello world');