旗下导航:搜·么
当前位置:网站首页 > PHP框架 > ThinkPHP > 正文

thinkphp 6.0 swoole扩大websocket运用教程【ThinkPHP教程】

作者:搜搜PHP网发布时间:2019-11-27分类:ThinkPHP浏览:109


导读:媒介ThinkPHP行将迎来最新版本6.0,针对现在愈来愈盛行Swoole,thinkphp也推出了最新的扩大think-swoole3.0。引见行将推出的t...

媒介

ThinkPHP行将迎来最新版本6.0,针对现在愈来愈盛行Swoole,thinkphp也推出了最新的扩大think-swoole 3.0。

引见

行将推出的tp6.0,已适配swoole.并推出think-swoole 3.0,而且默许适配了socketio。和2.0版本在运用要领上面有些许差别。

Websocket 继续与Http,举行websocket衔接之前须要一次HTTP要求,假如当期地点支撑websocket则返回101,然后举行衔接。也就是说并非我的效劳支撑websocket后,要求每一个衔接地点都能够举行websocket衔接,而是须要预先适配才能够衔接。

参数设置

'server'           => [        'host'      => '0.0.0.0', // 监听地点
        'port'      => 808, // 监听端口
        'mode'      => SWOOLE_PROCESS, // 运转形式 默许为SWOOLE_PROCESS
        'sock_type' => SWOOLE_SOCK_TCP, // sock type 默许为SWOOLE_SOCK_TCP
        'options'   => [            'pid_file'              => runtime_path() . 'swoole.pid',            'log_file'              => runtime_path() . 'swoole.log',            'daemonize'             => false,            // Normally this value should be 1~4 times larger according to your cpu cores.
            'reactor_num'           => swoole_cpu_num(),            'worker_num'            => swoole_cpu_num(),            'task_worker_num'       => 4,//swoole_cpu_num(),
            'enable_static_handler' => true,            'document_root'         => root_path('public'),            'package_max_length'    => 20 * 1024 * 1024,            'buffer_output_size'    => 10 * 1024 * 1024,            'socket_buffer_size'    => 128 * 1024 * 1024,            'max_request'           => 3000,            'send_yield'            => true,
        ],
    ],    'websocket'        => [        'enabled'       => true,// 开启websocket
        'handler'       => Handler::class,  //自定义wbesocket绑定类
        'parser'        => Parser::class, //自定义剖析类
        'route_file'    => base_path() . 'websocket.php',        'ping_interval' => 25000,        'ping_timeout'  => 60000,        'room'          => [            'type'        => TableRoom::class,            'room_rows'   => 4096,            'room_size'   => 2048,            'client_rows' => 8192,            'client_size' => 2048,
        ],
    ],    'auto_reload'      => true,    'enable_coroutine' => true,    'resetters'        => [],    'tables'           => [],

handler和parser大大方便了自定义websocket效劳,默许系统集成socketio。

本文重要引见怎样运用socketio,这里假定人人有socketio有肯定相识和运用基本。

socketIo默许会在要求地点后加响应的参数

同时,socketio默许情况下,会以为 http://url/socket.io/ 是支撑websocket效劳的地点。

而在tp-swoole3.0内部已对该地点要求举行了处置惩罚

<?phpnamespace think\swoole\websocket\socketio;use think\Config;use think\Cookie;use think\Request;class Controller{    protected $transports = ['polling', 'websocket'];    public function upgrade(Request $request, Config $config, Cookie $cookie)
    {        if (!in_array($request->param('transport'), $this->transports)) {            return json(
                [                    'code'    => 0,                    'message' => 'Transport unknown',
                ],                400
            );
        }        if ($request->has('sid')) {
            $response = response('1:6');
        } else {
            $sid     = base64_encode(uniqid());
            $payload = json_encode(
                [                    'sid'          => $sid,                    'upgrades'     => ['websocket'],                    'pingInterval' => $config->get('swoole.websocket.ping_interval'),                    'pingTimeout'  => $config->get('swoole.websocket.ping_timeout'),
                ]
            );
            $cookie->set('io', $sid);
            $response = response('97:0' . $payload . '2:40');
        }        return $response->contentType('text/plain');
    }    public function reject(Request $request)
    {        return json(
            [                'code'    => 3,                'message' => 'Bad request',
            ],            400
        );
    }
}

TP6.0,插件注册采用了service体式格局举行了注册,可在tp-swoole 效劳注册文件中检察路由注册信息,假如想自定义链接划定规矩,则能够掩盖该路由。

<?php// +----------------------------------------------------------------------// | ThinkPHP [ WE CAN DO IT JUST THINK IT ]// +----------------------------------------------------------------------// | Copyright (c) 2006-2018 http://thinkki4.cn All rights reserved.// +----------------------------------------------------------------------// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )// +----------------------------------------------------------------------// | Author: yunwuxin <448901948@qq.com>// +----------------------------------------------------------------------namespace think\swoole;use Swoole\Http\Server as HttpServer;use Swoole\Websocket\Server as WebsocketServer;use think\App;use think\Route;use think\swoole\command\Server as ServerCommand;use think\swoole\facade\Server;use think\swoole\websocket\socketio\Controller;use think\swoole\websocket\socketio\Middleware;class Service extends \think\Service{    protected $isWebsocket = false;    /**
     * @var HttpServer | WebsocketServer
     */
    protected static $server;    public function register()
    {        $this->isWebsocket = $this->app->config->get('swoole.websocket.enabled', false);        $this->app->bind(Server::class, function () {            if (is_null(static::$server)) {                $this->createSwooleServer();
            }            return static::$server;
        });        $this->app->bind('swoole.server', Server::class);        $this->app->bind(Swoole::class, function (App $app) {            return new Swoole($app);
        });        $this->app->bind('swoole', Swoole::class);
    }    public function boot(Route $route)
    {        $this->commands(ServerCommand::class);        if ($this->isWebsocket) {
            $route->group(function () use ($route) {
                $route->get('socket.io/', '@upgrade');
                $route->post('socket.io/', '@reject');
            })->prefix(Controller::class)->middleware(Middleware::class);
        }
    }    /**
     * Create swoole server.
     */
    protected function createSwooleServer()
    {
        $server     = $this->isWebsocket ? WebsocketServer::class : HttpServer::class;
        $config     = $this->app->config;
        $host       = $config->get('swoole.server.host');
        $port       = $config->get('swoole.server.port');
        $socketType = $config->get('swoole.server.socket_type', SWOOLE_SOCK_TCP);
        $mode       = $config->get('swoole.server.mode', SWOOLE_PROCESS);        static::$server = new $server($host, $port, $mode, $socketType);
        $options = $config->get('swoole.server.options');        static::$server->set($options);
    }
}

Socketio默许运用demo

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="./static/js/socket.io.js"></script></head><body><script>
    const socket = io('http://localhost:808');
    socket.emit("test", "your message");
    socket.on("test",function(res){console.log(res)});</script></body></html>

Websocket路由设置要领

在app目录下新建websocket.php文件,个中须要注重,因为运用了反射,闭包参数称号不能随便定义,不然没法注入。第一个参数是websocket,是当前websocket的Server对象,第二个参数data是客户端发送的数据。个中socketio emit的第一个参数和Websocket::on的第一个参数一致,作为事宜称号。

<?php/**
 * Author:Xavier Yang
 * Date:2019/6/5
 * Email:499873958@qq.com
 */use \think\swoole\facade\Websocket;
Websocket::on("test", function (\think\swoole\Websocket $websocket, $data) {    //var_dump($class);
    $websocket->emit("test", "asd");
});
Websocket::on("test1", function ($websocket, $data) {
    $websocket->emit("test", "asd");
});
Websocket::on("join", function (\think\swoole\Websocket $websocket, $data) {
    $websocket->join("1");
});

参考如上要领即可运用全新的websocket效劳。固然tp-swoole3.0一样另有很多其他的新功用,这些功用须要人人去探索尝试。
我也会在接下来的文章中,一同与人人分享我的运用历程。

更多ThinkPHP相干技术文章,请接见ThinkPHP运用教程栏目举行进修!

以上就是thinkphp 6.0 swoole扩大websocket运用教程的细致内容,更多请关注ki4网别的相干文章!

标签:thinkphp 6.0