作者:柯云,来自原文地址
微信小程序的websocket必须是wss协议,
于是捣鼓给swoole的websocket server加入SSL支持。
第一步,准备好自己的域名,备案等,就不啰嗦了。
第二步,到阿里云申请免费的证书服务。
按照提示一步步进行,最后下载得到一个pem文件和一个key文件。
将文件上传到服务器上。
第三步,将证书对应的域名,解析到swoole服务器的IP上。
第四步,重新编译安装swoole,加入ssl支持
-
cd swoole-src
-
phpize
-
./configure --enable-openssl
-
make && make install
当然,要先确保你的系统安装了openssl,php也安装了openssl扩展
第五步,编码,创建支持ssl的websocket服务
-
$ws = new swoole_websocket_server("0.0.0.0", 9502, SWOOLE_PROCESS, SWOOLE_SOCK_TCP | SWOOLE_SSL);
-
$key_dir = "/usr/local/ca";
-
-
$ws->set(array(
-
'worker_num' => 4,
-
'ssl_cert_file' => $key_dir.'/xxxxxxxxxxxx.pem',
-
'ssl_key_file' => $key_dir.'/xxxxxxxxxxxx.key',
-
));
以上,基本实现了一个wss协议的websocket服务
ps:如基于web来连接wss,web也需要是https
nginx配置HTTPS支持
修改Nginx配置文件,让其包含新标记的证书和私钥:
-
server {
-
server_name YOUR_DOMAINNAME_HERE;
-
listen 443;
-
ssl on;
-
ssl_certificate /usr/local/nginx/conf/xxxxxxxxxxxx.pem;
-
ssl_certificate_key /usr/local/nginx/conf/xxxxxxxxxxxx.key;
-
}
重启nginx。
crt文件可以直接用我们的pem文件替换
|