多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
# Workerman ## Workerman Workerman是一款纯PHP开发的开源高性能的PHP socket 服务器框架。被广泛的用于手机app、手游服务端、网络游戏服务器、聊天室服务器、硬件通讯服务器、智能家居、车联网、物联网等领域的开发。 支持TCP长连接,支持Websocket、HTTP等协议,支持自定义协议。基于workerman开发者可以更专注于业务逻辑开发,不必再为PHP Socket底层开发而烦恼。 首先通过 composer 安装 ``` composer require topthink/think-worker ``` 如果需要在window下做服务端,还需要 ``` composer require workerman/workerman-for-win ``` 运行出现错误PHP Fatal error: Call to undefined function Workerman\\Lib\\pcntl\_signal(),需要删除vendor\\workerman\\workerman,防止命名覆盖。 服务端使用示例如下: 在项目根目录新增启动服务文件server.php ``` #!/usr/bin/env php <?php namespace think; define('APP_PATH', __DIR__ . '/application/'); // 加载基础文件 require __DIR__ . '/thinkphp/base.php'; // 执行应用并响应 Container::get('app',[APP_PATH])->bind('push/Worker')->run()->send(); ``` 新增服务处理类(`push.app`是本地测试域名) ``` <?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('我收到你的信息了'); } /** * 当连接建立时触发的回调函数 * @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) { } } ``` 在命令行下运行,启动监听服务 ``` php server.php ``` 打开chrome浏览器,先打开`push.app`域名下的网页(js跨域不能通讯),按F12打开调试控制台,在Console一栏输入(或者把下面代码放入到html页面用js运行) ``` ws = new WebSocket("ws://push.app:2346"); ws.onopen = function() { alert("连接成功"); ws.send('tom'); alert("给服务端发送一个字符串:tom"); }; ws.onmessage = function(e) { alert("收到服务端的消息:" + e.data); }; ``` 继续测试 ``` ws.send('保持连接,发第二次信息,查看服务器回应'); ```