Workerman
Workerman是一款純PHP開(kai)發(fa)(fa)的(de)開(kai)源高性能的(de)PHP socket 服(fu)務器(qi)框架。被廣泛(fan)的(de)用于手(shou)機app、手(shou)游服(fu)務端、網(wang)(wang)絡游戲服(fu)務器(qi)、聊天室服(fu)務器(qi)、硬件通訊服(fu)務器(qi)、智能家居、車聯(lian)網(wang)(wang)、物聯(lian)網(wang)(wang)等領域的(de)開(kai)發(fa)(fa)。 支(zhi)持(chi)TCP長(chang)連接(jie),支(zhi)持(chi)Websocket、HTTP等協議,支(zhi)持(chi)自定(ding)義協議。基于workerman開(kai)發(fa)(fa)者可以更專(zhuan)注于業(ye)務邏輯開(kai)發(fa)(fa),不必(bi)再為PHP Socket底層開(kai)發(fa)(fa)而煩惱。
首先通過(guo) composer 安(an)裝
composer require topthink/think-worker
如果需(xu)(xu)要(yao)在(zai)window下做服務端(duan),還需(xu)(xu)要(yao)
composer require workerman/workerman-for-win
運行出現錯誤PHP Fatal error: Call to undefined function Workerman\Lib\pcntl_signal(),需要刪除vendor\workerman\workerman,防止命名覆蓋
服務端(duan)使用示(shi)例如下:
新增啟(qi)動服務文(wen)件server.php,在項(xiang)目(mu)根目(mu)錄(lu)
#!/usr/bin/env php
<?php
define('APP_PATH', __DIR__ . '/application/');
define('BIND_MODULE','push/Worker');
// 加(jia)載框架引導文件
require __DIR__ . '/thinkphp/start.php';
新增(zeng)服(fu)務處(chu)理類,push.app是(shi)我本地測試(shi)域名
<?php
namespace app\push\controller;
use think\worker\Server;
class Worker extends Server
{
protected $socket = 'websocket://push.app:2346';
/**
* 收到信息
* @param $connection
* @param $data
*/
public function onMessage($connection, $data)
{
$connection->send('我收到你的信息(xi)了');
}
/**
* 當連接建立時觸發的回調函數
* @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)
{
}
}
在命(ming)令行(xing)下運行(xing),啟動(dong)監聽服務
php server.php
打(da)開chrome瀏覽器(qi),先打(da)開push.app域名下的網頁(ye)(js跨域不能通訊(xun)),按F12打(da)開調(diao)試控制臺,在(zai)Console一欄輸入(或(huo)者把下面(mian)代(dai)碼放入到html頁(ye)面(mian)用js運(yun)行)
ws = new WebSocket("ws://push.app:2346");
ws.onopen = function() {
alert("連接成功");
ws.send('tom');
alert("給服務端發送一個(ge)字符串:tom");
};
ws.onmessage = function(e) {
alert("收(shou)到服務端(duan)的消(xiao)息:" + e.data);
};
繼續測試
ws.send('保持連接,發第(di)二次信息,查(cha)看服務(wu)器回應');
