在成功利用swoole_websocket_server 开启websocket服务之后,遇到一个问题,大多数web都是https的,特别是涉及到安全性比较高,设计互联网金融、数字货币的时候,https都是必须的。这时候,因为安全问题,ws://连接会被禁止。
安装swoole的openssl支持。 (推荐学习: swoole视频教程)
重新编译安装swoole源码,加上--enable-openssl
%php_bin%/phpizecd swoole_src./configure --enable-opensslmake && make install
代码中使用websocket ssl代替ws
服务端,比较上次代码,做出以下改变即可
//初始化类的时候,加上openssl参数$serv = new swoole_websocket_server(":", 8080, swoole_process, swoole_sock_tcp | swoole_ssl);//配置证书文件位置$key_dir = "your_key_dir";$serv->set(array( 'work_num'=>1, 'ssl_cert_file'=>$key_dir.'/file.crt', 'ssl_key_file' =>$key_dir.'file.key' ) );
客户端,将连接换为wss即可
var wsl = "wss://domain/path";ws = new websocket(wsl);
以上就是swoole 能配置证书吗的详细内容。