windows下TP5 workerman的安装与简单demo
**
windows下TP5 workerman的安装与简单demo
**
1.安装composer(已经有composer跳过此步骤)
-
下载Composer安装包(地址:https://getcomposer.org/download/)。
-
在php.ini文档中打开extension=php_openssl.dll(注:就是将extension=php_openssl.dll前面的 ‘;’ 号删掉,然后保存)
-
开启下载的conposer-Setup.exe程序,点击next。安装程序会自动找到电脑上的php.exe的路径,如果路径为空,可以手动更改。然后再点击next(新手注意,php.exe一定是要在你用的那个版本的php.exe)。
-
一直点next知道finish完成。开始配置全局变量,右击计算机->选择属性->高级系统设置->高级->环境变量->选择下面的path编辑将php.exe的地址复制到path里面去保存,注意前面加个分号(如:;D:\php\PHPTutorial\php\php-7.0.12-nts)。
-
验证composer是否安装成功:按win+R -> 输入cmd -> 打开命令行界面 -> 然后输入composer -> 回车 -> 如果出现以下的界面,说明composer安装成功
2.在tp5项目上安装workerman
-例如:我的项目是在D:\php\PHPTutorial\WWW目录下,项目名是wechatIM,那么我们进入项目的根目录
-
执行安装workerman命令:composer require topthink/think-worker,如果报错就执行composer require topthink/think-worker=1.0.*(耐心等会,可能会比较慢)成功会显示如下图
-
如果需要在window下做服务端,还需要安装workerman-for-win。执行composer require workerman/workerman-for-win,成功如下图,并且你的项目下vender下会多一个叫workerman的文件夹。
3.测试workerman是否有用 -
新增启动服务文件server.php,在项目根目录,就是和入口文件同目录
#!/usr/bin/env php
<?php
define('APP_PATH', __DIR__ . '/application/');
define('BIND_MODULE','push/Worker');
// 加载框架引导文件
require __DIR__ . '/thinkphp/start.php';
- 新增模块push,并且在push模块下新增控制器Worker.php。
写入如下代码
<?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)
{
}
}
- 在命令行下进入项目根目录输入命令行php server.php,显示了workerman版本表示服务开启
- 打开chrome浏览器,先打开本地的任何一个网页(js跨域不能通讯),按F12打开调试控制台,在Console一栏输入(或者把下面代码放入到html页面用js运行)
ws = new WebSocket("ws://127.0.0.1:2346");
ws.onopen = function() {
alert("连接成功");
ws.send('tom');
alert("给服务端发送一个字符串:tom");
};
ws.onmessage = function(e) {
alert("收到服务端的消息:" + e.data);
};
再次测试
ws.send('保持连接,发第二次信息,查看服务器回应');
效果如下图