首頁 >php框架 >Workerman > 正文

TP5 如何整合 WorkerMan 以及 GatewayWorker

轉載2019-12-03 16:09:410761
phpStudy Linux 面板(小皮面板)
下面由workerman教程欄目給大家介紹TP5整合 WorkerMan 以及 GatewayWorker的方法,希望對需要的朋友有所幫助!

TP5整合GatewayWorker

Windows版安裝

a)使用composer create-project topthink/think testTG,來安裝thinkphp5.

b)進入thinkphp5的目錄,此處為testTG,使用composer require workerman/gateway-worker-for-win 安裝Windows版本的gateway。

c)去官網下載Windows版的gateway-worker,里面有demo。http://www.workerman.net/download

d)將下載的壓縮包解壓,將Applications/Yourapp中的文件全部復制到thinkphp5目錄application里面的任意文件夾,這里取名為push。

e)將解壓后的文件夾中的start_for_win.bat復制到thinkphp5的根目錄,即與application同級的目錄。

f)右鍵start_for_win.bat,點編輯,將里面的目錄改成自己的目錄,這里改為

php application\push\start_register.php application\push\start_gateway.php application\push\start_businessworker.php
Pause

g)保存退出。雙擊運行。

Linux版安裝

a)使用composer create-project topthink/think testTG,來安裝thinkphp5.

b)進入thinkphp5的目錄,此處為testTG,使用composer require workerman/gateway-worker 安裝Linux版本的gateway。

c)去官網下載Linux版的gateway-worker,里面有demo。http://www.workerman.net/download

d)將下載的壓縮包解壓,將Applications/Yourapp中的文件全部復制到thinkphp5目錄application里面的任意文件夾,這里取名為push。

e)將解壓后的文件夾中的start.php復制到thinkphp5的根目錄,即與application同級的目錄。

f)將start.php文件中最后部分forearch循環括號內的路徑改為自己的正確路徑。

在命令行php start.php start 啟動。

TP5整合WrokerMan

Windows版安裝

a)使用composer create-project topthink/think testTW,來安裝thinkphp5.

b)進入thinkphp5根目錄,即testTW。先使用composer require topthink/think-worker,

再使用composer require workerman/workerman-for-win,來安裝workerman。安裝成功之后刪除vendor\workerman\workerman。

c)在thinkphp5根目錄(即與application同級目錄)創建server.php,編輯一下內容。

<?php
efine('APP_PATH', __DIR__ . '/application/');
define('BIND_MODULE','push/Worker');
// 加載框架引導文件
require __DIR__ . '/thinkphp/start.php';

d)創建workerman的controller,命名為Worker.php。在application/push/controller,目錄不存在自行創建。添加以下內容:

protected $socket = 'websocket://127.0.0.1:2346'其中127.0.0.1為socket服務器所在的ip地址。此處監聽本機的2346端口。

<?php
namespace app\push\controller;
use think\worker\Server;
class Worker extends Server
{
    protected $socket = 'websocket://127.0.0.1:2346';
    /**
     * 收到信息
     * @param $connection
     * @param $data
     */
    public function onMessage($connection, $data)
    {
        $connection->send('我收到你的信息了');
    }
    /**
     * 當連接建立時觸發的回調函數
     * @param $connection
     */
    public function onConnect($connection)
    {
    }
    /**
     * 當連接斷開時觸發的回調函數
     * @param $connection
     */
    public function onClose($connection)
    {
        
    }
    /**
     * 當客戶端的連接上發生錯誤時觸發
     * @param $connection
     * @param $code
     * @param $msg
     */
    public function onError($connection, $code, $msg)
    {
        echo "error $code $msg\n";
    }
    /**
     * 每個進程啟動
     * @param $worker
     */
    public function onWorkerStart($worker)
    {
    }
}

e)在命令行下運行,啟動監聽服務php server.php

f)任意位置新建一個html文件。其中內容為:

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<script>
ws = new WebSocket("ws://localhost:2346");
ws.onopen = function() {
    alert("連接成功");
    ws.send('tom');
    alert("給服務端發送一個字符串:tom");
};
ws.onmessage = function(e) {
    alert("收到服務端的消息:" + e.data);
};
</script>

g)保存,用瀏覽器打開,就可以看到鏈接成功。

Linux版安裝

a)只需將Windows版安裝的b)步驟中的composer命令只執行:composer require topthink/think-worker。即可,其余步驟不變。

簡單使用GatewayWorker

<script type="text/javascript">
/**
 * 與GatewayWorker建立websocket連接,域名和端口改為你實際的域名端口,
 * 其中端口為Gateway端口,即start_gateway.php指定的端口。
 * start_gateway.php 中需要指定websocket協議,像這樣
 * $gateway = new Gateway(websocket://0.0.0.0:7272);
 */
ws = new WebSocket("ws://127.0.0.1:8282");
// 服務端主動推送消息時會觸發這里的onmessage
ws.onmessage = function(e){
    // json數據轉換成js對象
    var bindUrl = "{:url('push/BindClientId')}";
    var data = e.data;
    var type = data.type || '';
    switch(type){
        // Events.php中返回的init類型的消息,將client_id發給后臺進行uid綁定
        case 'init':
            // 利用jquery發起ajax請求,將client_id發給后端進行uid綁定
            $.post(bindUrl, {client_id: data.client_id}, function(data){
            }, 'json');
            break;
        // 當mvc框架調用GatewayClient發消息時直接alert出來
        default :
        var text = e.data;
            var str = '<li style="width:100%; height:60px; border:1px solid #000">' +text +'</li>';
            $('#message_box').append();
           // alert(e.data);
    }
};
</script>
class Push{
   
    public function helloAction () {
        $uid = $_GET['uid'];
        session('uid', $uid);
        $view = new View;
        return $view->fetch();
    }
    public function BindClientIdAction () {
        
        $client_id = $_POST['client_id'];
        // 設置GatewayWorker服務的Register服務ip和端口,請根據實際情況改成實際值
        Gateway::$registerAddress = '127.0.0.1:1238';
        $bindUid = session('uid');
        // 假設用戶已經登錄,用戶uid和群組id在session中
        // client_id與uid綁定
        Gateway::bindUid($client_id, $bindUid);
        // 加入某個群組(可調用多次加入多個群組)
        // Gateway::joinGroup($client_id, $group_id);
    }
    public function AjaxSendMessageAction () {
        $message = $_POST['message'];
        // 設置GatewayWorker服務的Register服務ip和端口,請根據實際情況改成實際值
        Gateway::$registerAddress = '127.0.0.1:1238';
        GateWay::sendToAll($message);
    }
}

以上就是TP5 如何整合 WorkerMan 以及 GatewayWorker的詳細內容,更多請關注php中文網其它相關文章!

php中文網最新課程二維碼
  • 相關標簽:WorkerMan
  • 本文轉載于:segmentfault,如有侵犯,請聯系[email protected]刪除
  • 相關文章

    相關視頻


      網友評論

      文明上網理性發言,請遵守 新聞評論服務協議

      我要評論
    • 專題推薦

      推薦視頻教程
    • javascript初級視頻教程javascript初級視頻教程
    • jquery 基礎視頻教程jquery 基礎視頻教程
    • 視頻教程分類
      118期四肖中特唯一