这是start.php
<?php
use Workerman\Worker;
define('APP_PATH',dirname(dirname(dirname(__FILE__))).'/');
define('API_PATH',APP_PATH.'/api/');
require_once API_PATH.'workerman/Autoloader.php';
// 证书最好是申请的证书
$context = array(
'ssl' => array(
'local_cert' => '/www/server/apache/cert/3469204_public.crt', // pem文件也可以是crt文件
'local_pk' => '/www/server/apache/cert/3469204.key', // key文件
'verify_peer' => false,
)
);
// 这里设置的是websocket协议,也可以http协议或者其它协议
$worker = new Worker('websocket://0.0.0.0:8765', $context);
// 设置transport开启ssl
$worker->transport = 'ssl';
$worker->onMessage = function($con, $msg) {
$con->send('ok');
};
Worker::runAll();
然后在浏览器Console中执行的代码是:
// 证书是会检查域名的,请使用域名连接
ws = new WebSocket("wss://mydomain.com/api/wss");
ws.onopen = function() {
alert("连接成功");
ws.send('tom');
alert("给服务端发送一个字符串:tom");
};
ws.onmessage = function(e) {
console.log(e);
alert("收到服务端的消息:" + e.data);
};
报错信息:
VM113:2 WebSocket connection to 'wss://mydomain.com/api/wss' failed: Error during WebSocket handshake: Invalid status line
服务器终端显示:
SSL handshake error: stream_socket_enable_crypto(): SSL operation failed with code 1. OpenSSL Error messages:
error:1407609C:SSL routines:SSL23_GET_CLIENT_HELLO:http request
已按照http://doc.workerman.net/faq/secure-websocket-server.html 创建wss服务
改成
加端口可以,是因为apache代理wss没有生效吗?
也没见你描述有使用apache代理;不管有没有代理,启用了SSL协议之后,客户端连接非443端口的时候都要显式的在域名后指定端口;另外使用apache或nginx代理的话,有不少注意事项,手册写的很清楚,一定要仔细看。
OK。明白了(注意如使用apache代理SSL,则workerman部分千万不要设置ssl,否则将无法连接)
对的,括号里这个经常有人踩雷。