這篇文章給大家分享的是有關(guān)TP5如何整合WorkerMan以及GatewayWorker的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
企業(yè)建站必須是能夠以充分展現(xiàn)企業(yè)形象為主要目的,是企業(yè)文化與產(chǎn)品對外擴(kuò)展宣傳的重要窗口,一個合格的網(wǎng)站不僅僅能為公司帶來巨大的互聯(lián)網(wǎng)上的收集和信息發(fā)布平臺,創(chuàng)新互聯(lián)建站面向各種領(lǐng)域:砂巖浮雕等網(wǎng)站設(shè)計、成都全網(wǎng)營銷解決方案、網(wǎng)站設(shè)計等建站排名服務(wù)。
TP5整合GatewayWorker
Windows版安裝
a)使用composer create-project topthink/think testTG,來安裝thinkphp5.
b)進(jìn)入thinkphp5的目錄,此處為testTG,使用composer require workerman/gateway-worker-for-win 安裝Windows版本的gateway。
c)去官網(wǎng)下載Windows版的gateway-worker,里面有demo。http://www.workerman.net/download
d)將下載的壓縮包解壓,將Applications/Yourapp中的文件全部復(fù)制到thinkphp5目錄application里面的任意文件夾,這里取名為push。
e)將解壓后的文件夾中的start_for_win.bat復(fù)制到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)保存退出。雙擊運(yùn)行。
Linux版安裝
a)使用composer create-project topthink/think testTG,來安裝thinkphp5.
b)進(jìn)入thinkphp5的目錄,此處為testTG,使用composer require workerman/gateway-worker 安裝Linux版本的gateway。
c)去官網(wǎng)下載Linux版的gateway-worker,里面有demo。http://www.workerman.net/download
d)將下載的壓縮包解壓,將Applications/Yourapp中的文件全部復(fù)制到thinkphp5目錄application里面的任意文件夾,這里取名為push。
e)將解壓后的文件夾中的start.php復(fù)制到thinkphp5的根目錄,即與application同級的目錄。
f)將start.php文件中最后部分forearch循環(huán)括號內(nèi)的路徑改為自己的正確路徑。
在命令行php start.php start 啟動。
TP5整合WrokerMan
Windows版安裝
a)使用composer create-project topthink/think testTW,來安裝thinkphp5.
b)進(jìn)入thinkphp5根目錄,即testTW。先使用composer require topthink/think-worker,
再使用composer require workerman/workerman-for-win,來安裝workerman。安裝成功之后刪除vendor\workerman\workerman。
c)在thinkphp5根目錄(即與application同級目錄)創(chuàng)建server.php,編輯一下內(nèi)容。
<?php efine('APP_PATH', __DIR__ . '/application/'); define('BIND_MODULE','push/Worker'); // 加載框架引導(dǎo)文件 require __DIR__ . '/thinkphp/start.php';
d)創(chuàng)建workerman的controller,命名為Worker.php。在application/push/controller,目錄不存在自行創(chuàng)建。添加以下內(nèi)容:
protected $socket = 'websocket://127.0.0.1:2346'其中127.0.0.1為socket服務(wù)器所在的ip地址。此處監(jiān)聽本機(jī)的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('我收到你的信息了'); } /** * 當(dāng)連接建立時觸發(fā)的回調(diào)函數(shù) * @param $connection */ public function onConnect($connection) { } /** * 當(dāng)連接斷開時觸發(fā)的回調(diào)函數(shù) * @param $connection */ public function onClose($connection) { } /** * 當(dāng)客戶端的連接上發(fā)生錯誤時觸發(fā) * @param $connection * @param $code * @param $msg */ public function onError($connection, $code, $msg) { echo "error $code $msg\n"; } /** * 每個進(jìn)程啟動 * @param $worker */ public function onWorkerStart($worker) { } }
e)在命令行下運(yùn)行,啟動監(jiān)聽服務(wù)php server.php
f)任意位置新建一個html文件。其中內(nèi)容為:
<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("給服務(wù)端發(fā)送一個字符串:tom"); }; ws.onmessage = function(e) { alert("收到服務(wù)端的消息:" + e.data); }; </script>
g)保存,用瀏覽器打開,就可以看到鏈接成功。
Linux版安裝
a)只需將Windows版安裝的b)步驟中的composer命令只執(zhí)行:composer require topthink/think-worker。即可,其余步驟不變。
簡單使用GatewayWorker
<script type="text/javascript"> /** * 與GatewayWorker建立websocket連接,域名和端口改為你實際的域名端口, * 其中端口為Gateway端口,即start_gateway.php指定的端口。 * start_gateway.php 中需要指定websocket協(xié)議,像這樣 * $gateway = new Gateway(websocket://0.0.0.0:7272); */ ws = new WebSocket("ws://127.0.0.1:8282"); // 服務(wù)端主動推送消息時會觸發(fā)這里的onmessage ws.onmessage = function(e){ // json數(shù)據(jù)轉(zhuǎn)換成js對象 var bindUrl = "{:url('push/BindClientId')}"; var data = e.data; var type = data.type || ''; switch(type){ // Events.php中返回的init類型的消息,將client_id發(fā)給后臺進(jìn)行uid綁定 case 'init': // 利用jquery發(fā)起ajax請求,將client_id發(fā)給后端進(jìn)行uid綁定 $.post(bindUrl, {client_id: data.client_id}, function(data){ }, 'json'); break; // 當(dāng)mvc框架調(diào)用GatewayClient發(fā)消息時直接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']; // 設(shè)置GatewayWorker服務(wù)的Register服務(wù)ip和端口,請根據(jù)實際情況改成實際值 Gateway::$registerAddress = '127.0.0.1:1238'; $bindUid = session('uid'); // 假設(shè)用戶已經(jīng)登錄,用戶uid和群組id在session中 // client_id與uid綁定 Gateway::bindUid($client_id, $bindUid); // 加入某個群組(可調(diào)用多次加入多個群組) // Gateway::joinGroup($client_id, $group_id); } public function AjaxSendMessageAction () { $message = $_POST['message']; // 設(shè)置GatewayWorker服務(wù)的Register服務(wù)ip和端口,請根據(jù)實際情況改成實際值 Gateway::$registerAddress = '127.0.0.1:1238'; GateWay::sendToAll($message); } }
感謝各位的閱讀!關(guān)于“TP5如何整合WorkerMan以及GatewayWorker”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
當(dāng)前名稱:TP5如何整合WorkerMan以及GatewayWorker
網(wǎng)站URL:http://m.2m8n56k.cn/article26/jdsijg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、移動網(wǎng)站建設(shè)、電子商務(wù)、App開發(fā)、營銷型網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)