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
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);
}
}
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)儲存,用浏覽器打開,就可以看到連結成功。