大神给看看什么情况:Error during WebSocket handshake: Invalid status line

coker

这是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 
3325 2 0
2个回答

coker

已按照http://doc.workerman.net/faq/secure-websocket-server.html 创建wss服务

  • 暂无评论
blogdaren
ws = new WebSocket("wss://mydomain.com/api/wss");

改成

ws = new WebSocket("wss://mydomain.com:8765/api/wss");
  • coker 2020-03-10

    加端口可以,是因为apache代理wss没有生效吗?

  • blogdaren 2020-03-10

    也没见你描述有使用apache代理;不管有没有代理,启用了SSL协议之后,客户端连接非443端口的时候都要显式的在域名后指定端口;另外使用apache或nginx代理的话,有不少注意事项,手册写的很清楚,一定要仔细看。

  • coker 2020-03-10

    OK。明白了(注意如使用apache代理SSL,则workerman部分千万不要设置ssl,否则将无法连接)

  • blogdaren 2020-03-10

    对的,括号里这个经常有人踩雷。

年代过于久远,无法发表回答
🔝