0

0

如何在 HTTPS 网站上正确部署 WebSocket 服务器(WSS)

碧海醫心

碧海醫心

发布时间:2026-01-17 23:08:02

|

175人浏览过

|

来源于php中文网

原创

如何在 HTTPS 网站上正确部署 WebSocket 服务器(WSS)

本文详解为何 `wss://` 连接失败的根本原因,并提供完整、可运行的 express + websocket(ws)服务端配置方案,涵盖 https 证书集成、端口复用、升级处理及客户端连接要点。

WebSocket 客户端使用 wss:// 协议时,必须通过 HTTPS 服务器进行 TLS 加密通信,而不能直接复用纯 HTTP 服务或未配置证书的 http.createServer()。你原代码中调用 http.createServer(app).listen() 启动的是明文 HTTP 服务,却试图让浏览器以安全协议 wss:// 连接 —— 浏览器会直接拒绝握手,抛出 WebSocket connection failed 错误,这是由浏览器安全策略强制执行的,无法绕过。

✅ 正确做法:复用 HTTPS 服务并显式处理 Upgrade 请求

你需要:

  1. 使用 https.createServer() 启动主服务,传入 SSL 私钥(.key)和证书(.crt 或 .pem);
  2. 将 Express 应用挂载到该 HTTPS 服务上
  3. 监听 'upgrade' 事件,在收到 WebSocket 升级请求时,交由 wss.handleUpgrade() 处理(而非在路由中调用);
  4. 确保前端 WebSocket 构造函数 URL 与服务端 HTTPS 域名、路径、协议完全一致

以下是修复后的完整服务端代码(server.js):

京点点
京点点

京东AIGC内容生成平台

下载
const fs = require('fs');
const https = require('https');
const express = require('express');
const WebSocket = require('ws');

const app = express();
const wss = new WebSocket.Server({ noServer: true });

// ✅ 关键:读取真实 SSL 证书(请替换为你的实际路径)
const httpsOptions = {
  key: fs.readFileSync('/etc/letsencrypt/live/example.com/privkey.pem'),
  cert: fs.readFileSync('/etc/letsencrypt/live/example.com/fullchain.pem')
};

// ✅ 使用 https.createServer,而非 http
const server = https.createServer(httpsOptions, app);

// ✅ 暴露 /multiplayerChat2/ 路由仅作“触发升级”的入口(返回 200 即可)
app.get('/multiplayerChat2/', (req, res) => {
  res.status(200).send('WebSocket endpoint ready. Connect via wss://example.com/multiplayerChat2/');
});

// ✅ 监听 upgrade 事件,精准匹配路径后交由 wss 处理
server.on('upgrade', (req, socket, head) => {
  if (req.url === '/multiplayerChat2/') {
    wss.handleUpgrade(req, socket, head, (ws) => {
      console.log('✅ Client connected via WSS');
      ws.on('message', (data) => {
        const msg = data.toString('utf8').substring(0, 50);
        wss.clients.forEach(client => {
          if (client.readyState === WebSocket.OPEN) {
            client.send(msg);
          }
        });
      });
      ws.on('close', () => console.log('❌ Client disconnected'));
      ws.on('error', (err) => console.error('WebSocket error:', err));
    });
  } else {
    socket.destroy(); // 拒绝非目标路径的升级请求
  }
});

// ✅ 绑定到标准 HTTPS 端口(443),需 root 权限;生产环境建议用反向代理(如 Nginx)卸载 SSL
const PORT = process.env.PORT || 443;
server.listen(PORT, () => {
  console.log(`✅ HTTPS + WSS server running on https://example.com:${PORT}`);
});

? 客户端注意事项(关键修正)

  • 确保 WebSocket URL 中的域名与证书绑定域名完全一致(如 wss://example.com,不能是 www.example.com 除非证书也覆盖它);
  • 若使用 Let’s Encrypt,推荐通配符证书或 SAN 证书包含所有子域;
  • 开发调试时可临时用 wss://localhost:443 + 自签名证书(需手动信任),但生产环境必须使用权威 CA 签发证书;
  • 浏览器控制台 → Security 标签页可验证当前页面是否为“Secure context”,只有 secure context 才允许 wss://。

⚠️ 常见误区澄清

错误做法 正确做法
http.createServer().listen(443) 必须用 https.createServer(options),HTTP 无法承载 WSS
在 app.get() 内调用 wss.handleUpgrade() handleUpgrade 必须在 'upgrade' 事件中调用,否则无 socket 和 head 参数
未校验 req.url 就处理所有 upgrade 攻击者可伪造任意路径升级请求,务必白名单校验
用 process.env.PORT 但未配置反代或权限 若直接监听 443,Node 进程需 sudo;更佳实践是用 Nginx 反向代理:Nginx 终止 SSL → 转发 ws://localhost:8080 到 Node

✅ 推荐生产架构(免 root & 高可靠)

# Nginx 配置片段(/etc/nginx/sites-available/example.com)
location /multiplayerChat2/ {
  proxy_pass http://localhost:8080;
  proxy_http_version 1.1;
  proxy_set_header Upgrade $http_upgrade;
  proxy_set_header Connection "upgrade";
  proxy_set_header Host $host;
  proxy_set_header X-Real-IP $remote_addr;
}

此时 Node 监听 localhost:8080(无需证书),Nginx 负责 HTTPS 终止与 WebSocket 协议升级转发 —— 安全、灵活、符合运维规范。

至此,你的 wss://example.com/multiplayerChat2/ 将稳定建立连接。记住核心原则:WSS 不是独立服务,而是 HTTPS 连接上的协议升级通道,一切必须围绕 HTTPS 服务构建。

相关专题

更多
nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

229

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

498

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

498

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

227

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

333

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3508

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

14

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.3万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号