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?applicationpushstart_register.php?applicationpushstart_gateway.php?applicationpushstart_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。安裝成功之后刪除vendorworkermanworkerman。

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

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

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 apppushcontroller;   use thinkworkerServer;   class Worker extends Server {     protected $socket = &#39;websocket://127.0.0.1:2346&#39;;       /**      * 收到信息      * @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?$msgn"; ????} ? ????/** ?????*?每個進程啟動 ?????*?@param?$worker ?????*/ ????public?function?onWorkerStart($worker) ????{ ? ????} }

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

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

<meta><script> ws = new WebSocket("ws://localhost:2346"); ws.onopen = function() {     alert("連接成功");     ws.send(&#39;tom&#39;);     alert("給服務端發送一個字符串:tom"); }; ws.onmessage = function(e) {     alert("收到服務端的消息:" + e.data); }; </script>

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

Linux版安裝

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

簡單使用GatewayWorker

<script> /**  * 與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(&#39;push/BindClientId&#39;)}";     var data = e.data;       var type = data.type || &#39;&#39;;     switch(type){         // Events.php中返回的init類型的消息,將client_id發給后臺進行uid綁定         case &#39;init&#39;:             // 利用jquery發起ajax請求,將client_id發給后端進行uid綁定             $.post(bindUrl, {client_id: data.client_id}, function(data){               }, &#39;json&#39;);             break;         // 當mvc框架調用GatewayClient發消息時直接alert出來         default :         var text = e.data;             var str = &#39;<li style="width:100%; height:60px; border:1px solid #000">&#39; +text +&#39;&#39;;             $(&#39;#message_box&#39;).append();            // alert(e.data);     } }; </script> class?Push{ ??? ????public?function?helloAction?()?{ ????????$uid?=?$_GET['uid']; ????????session('uid',?$uid); ? ????????$view?=?new?View; ????????return?$view-&gt;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); ????} }

? 版權聲明
THE END
喜歡就支持一下吧
點贊15 分享