tp5 think-swoole websocket开启ssl wss可以请求

新开发发的项目用户端是公众号和小程序,小程序只支持wss链接,以下是我的开启wss的方法,以及过程中遇到的一些问题(主要是我菜)
首先需要有证书,我用的是宝塔面板申请的免费证书,宝塔申请的免费证书路径在/etc/letsencrypt/live/,会列出来所有申请了免费证书的网站,公司服务器就不放截图了。一定要记住这个路径,后面用得到。然后是swoole需要开启openssl,我的是宝塔面板安装的swoole好像默认是开启的,查资料的时候发现有的不是默认开启的需要重新安装编译,如果需要手动编译安装可以查看比如https://qq52o.me/2700.html,https://www.php.cn/swoole/437812.html还有https://www.cnblogs.com/hodge01/p/8658296.html,任君挑选
最后是websocket控制器,这里是在下面这位大佬的代码基础上改的https://blog.csdn.net/msllws/article/details/84405127
注意!!!!以下代码被我删除了大量业务代码,配置可以直接参考,业务逻辑需要自己完善。

<?php

namespace app\index\controller;


use think\Db;
use think\swoole\Server;

class WebsocketController extends Server
{
    protected $host = '0.0.0.0'; //监听所有地址
    protected $port = 9501; //监听9501端口
    protected $serverType = 'ssl';
    protected $mode = SWOOLE_PROCESS;
    protected $sockType = SWOOLE_SOCK_TCP | SWOOLE_SSL;
    protected $option = [
        'worker_num' => 4, //设置启动的Worker进程数
        'daemonize' => false, //守护进程化(上线改为true)
        'backlog' => 128, //Listen队列长度
        'dispatch_mode' => 2, //固定模式,保证同一个连接发来的数据只会被同一个worker处理

        //心跳检测:每60秒遍历所有连接,强制关闭10分钟内没有向服务器发送任何数据的连接
        'heartbeat_check_interval' => 60,
        'heartbeat_idle_time' => 600,
        //配置SSL证书和密钥路径
        'ssl_cert_file' => "/etc/letsencrypt/live/xxx/fullchain.pem",
        'ssl_key_file'  => "/etc/letsencrypt/live/xxx/privkey.pem"
    ];

    //建立连接时回调函数
    public function onOpen($server, $req)
    {
        $fd = $req->fd;//客户端标识
        $user_id = $req->get['user_id'];//客户端传递的用户id
        $arr = array('code' => 1, 'info' => '查询成功');
        $server->push($fd, json_encode($arr));
        echo "用户".$user_id."建立了连接,标识为".$fd ."\n";
    }

    //接收数据时回调函数
    public function onMessage($server, $frame)
    {
        $fd = $frame->fd;
        $message = $frame->data;
        $arr = array('code' => 1, 'info' => '查询成功', 'data' => $order);
         //查询对应用户的标识,推送给对应用户,群组聊天可以循环推
        $server->push($fd , json_encode($arr));
     }


    //连接关闭时回调函数
    public function onClose($server, $fd)
    {
        echo "标识{$fd}关闭了连接\n";
    }
}

然后在server.php里面添加以下代码

case 'ssl':
                $this->swoole = new Websocket($this->host, $this->port, $this->mode, $this->sockType);
                break;

在这里插入图片描述
然后开启服务,最后说一下,我踩过的坑,启动服务之后小程序可以正常连上,但是公众号怎么都连不上,报的一个错是net::ERR_CERT_COMMON_NAME_INVALID,网上查到的方法基本 都是修改证书或者修改浏览器,但是公众号上操作并不现实,一些漫不经意的说话将我疑惑解开,同事问了一句诶,你们怎么没用域名请求呢,域名请求,域名。。。。。。我一开始开发测试的时候一直都用的ip,配置了证书之后忘记了改成域名Σ( ° △ °|||)︴

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章