令人困惑的 websocket tls 功能

Posted

技术标签:

【中文标题】令人困惑的 websocket tls 功能【英文标题】:confusing websocket tls functionality 【发布时间】:2020-11-15 23:13:43 【问题描述】:

我今天试用了一个名为 uwebsockets 的 websocket 库。 我的代码只是他们 github 上提供的示例之一。

int main() 

struct PerSocketData 

;

std::vector<std::thread*> threads(std::thread::hardware_concurrency());

std::transform(threads.begin(), threads.end(), threads.begin(), [](std::thread* t) 
    return new std::thread([]() 

        uWS::SSLApp(
            /* There are example certificates in uWebSockets.js repo */
            .key_file_name = "", 
            .cert_file_name = "", 
            ).ws<PerSocketData>("/*", 
                /* Settings */
                .compression = uWS::SHARED_COMPRESSOR,
                .maxPayloadLength = 16 * 1024,
                .idleTimeout = 30,
                .maxBackpressure = 1 * 1024 * 1024,
                
            /* Handlers */
            .open = [](auto* ws) 

                std::cout << "connected" << std::endl;
            ,
            .message = [](auto* ws, std::string_view message, uWS::OpCode opCode) 
                ws->send(message, opCode);
                

            ,
            .drain = [](auto* ws) 
                /* Check getBufferedAmount here */
            ,
            .ping = [](auto* ws) 

            ,
            .pong = [](auto* ws) 

            ,
            .close = [](auto* ws, int code, std::string_view message) 

            
            ).listen(8443, [](auto* token) 
                if (token) 
                    std::cout << "Thread " << std::this_thread::get_id() << " listening on port " << 8443 << std::endl;
                
                else 
                    std::cout << "Thread " << std::this_thread::get_id() << " failed to listen on port 9001" << std::endl;
                
            ).run();

    );
);

std::for_each(threads.begin(), threads.end(), [](std::thread* t) 
    t->join();
);

如您所见,我没有提供密钥目录或证书目录,但在我的服务器(Windows Server 2016 IIS)上运行此示例,我可以使用https://www.websocket.org/echo.html 等测试站点在我的浏览器中连接到此示例。

我认为甚至需要证书才能使其连接,但我没有收到任何错误并且能够连接。为什么是这样? 这是我服务器端的某种问题吗?

【问题讨论】:

如何连接到 websocket 主机很重要 - Yauheni 的回答可能是正确的,但知道您是否能够连接到 ws://wss:// 在诊断上很有用。它也有助于提供网络内容的客户端! 【参考方案1】:

确保您构建的 uWebSockets 支持 SSL:

make -e WITH_OPENSSL=1

默认情况下,它是在没有 SSL 的情况下构建的,在这种情况下,据我所知,uWS::SSLApp 就像 uWS::App 一样工作。证书选项被静默忽略。

【讨论】:

以上是关于令人困惑的 websocket tls 功能的主要内容,如果未能解决你的问题,请参考以下文章

@SessionAttribute 令人困惑

Websockets + TLS 的 Mosquitto 配置

将 WebSocket 升级到 TLS

WebSocket TLS 证书设置乐趣

如何创建安全(TLS/SSL)Websocket 服务器

C# - 使用 feck 的 TLS / SSL Websockets