# 记录在腾讯云服务器部署wss证书到linux系统下由docker创建的nginx反向代理服务器,实现nodejs项目ws转wss协议

记录在腾讯云服务器部署wss证书到linux系统下由docker创建的nginx反向代理服务器,实现nodejs项目ws转wss协议

获取域名证书(我这里是子域名:www.smartlife.ws.server.xingnang.cc)

  • 进入腾讯云控制台里的SSL证书页面https://console.cloud.tencent.com/ssl
    在这里插入图片描述

  • 点击申请免费证书

    • 域名验证方式建议使用自动DNS验证
      在这里填写申请的域名证书
  • 等待证书申请通过签发成功后下载证书文件到本地
    在这里插入图片描述

  • 由于我这里是nginx代理服务器,所以选择第4个nginx
    在这里插入图片描述

  • 把本地证书文件解压后上传到linux服务器(这里我使用的是WinSCP软件)

  • 修改nginx配置,设置上传的证书路径
    nginx的http里的配置

        # 行囊物联-智慧生活,wss服务的访问配置
        server {
                server_name www.smartlife.ws.server.xingnang.cc;
                listen      443 ssl;
                ssl_certificate cert/www.smartlife.ws.server.xingnang.cc_nginx/www.smartlife.ws.server.xingnang.cc_bundle.crt; # crt路径
                ssl_certificate_key cert/www.smartlife.ws.server.xingnang.cc_nginx/www.smartlife.ws.server.xingnang.cc.key; # key路径
                ssl_session_timeout 5m;
                ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
                ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
                ssl_prefer_server_ciphers on;


                location / {
                        proxy_connect_timeout 4s;
                        proxy_read_timeout 7200s;
                        proxy_send_timeout 12s;
                        proxy_pass http://xn-smart_life_server:8080;

                        proxy_set_header Upgrade $http_upgrade; # ws 协议需要设置
                        proxy_set_header Connection "upgrade";

                }
       }


  • 上述步骤完成后,原本的ws就可以通过wss协议访问了
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 Java 中使用 WSS 协议与使用 WS 协议的代码基本相同,只需要在 WebSocket URI 中将 `ws` 替换为 `wss`,并且使用 SSLContext 来配置 SSL/TLS 加密。下面是一个简单的 WSS 协议的 WebSocket 服务器示例: ```java import java.net.InetSocketAddress; import java.security.KeyStore; import javax.net.ssl.KeyManagerFactory; import javax.net.ssl.SSLContext; import javax.net.ssl.TrustManagerFactory; import com.sun.net.httpserver.HttpContext; import com.sun.net.httpserver.HttpsConfigurator; import com.sun.net.httpserver.HttpsServer; import com.sun.net.httpserver.HttpsParameters; import com.sun.net.httpserver.HttpsServerProvider; import com.sun.net.httpserver.spi.HttpServerProvider; import org.java_websocket.server.DefaultSSLWebSocketServerFactory; import org.java_websocket.server.WebSocketServer; public class WssWebSocketServer extends WebSocketServer { public WssWebSocketServer(InetSocketAddress address) { super(address); } @Override public void onOpen(WebSocket conn, ClientHandshake handshake) { // 处理 WebSocket 连接建立事件 } @Override public void onClose(WebSocket conn, int code, String reason, boolean remote) { // 处理 WebSocket 连接关闭事件 } @Override public void onMessage(WebSocket conn, String message) { // 处理 WebSocket 收到消息事件 } @Override public void onError(WebSocket conn, Exception ex) { // 处理 WebSocket 错误事件 } public static void main(String[] args) { try { // 加载证书和密钥 char[] password = "password".toCharArray(); KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType()); keyStore.load(WssWebSocketServer.class.getResourceAsStream("/keystore.jks"), password); KeyManagerFactory keyManagerFactory = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm()); keyManagerFactory.init(keyStore, password); TrustManagerFactory trustManagerFactory = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm()); trustManagerFactory.init(keyStore); // 配置 SSLContext SSLContext sslContext = SSLContext.getInstance("TLS"); sslContext.init(keyManagerFactory.getKeyManagers(), trustManagerFactory.getTrustManagers(), null); // 创建 WSS 协议的 WebSocket 服务器 InetSocketAddress address = new InetSocketAddress("localhost", 8080); WssWebSocketServer server = new WssWebSocketServer(address); // 配置 SSL/TLS 加密 server.setWebSocketFactory(new DefaultSSLWebSocketServerFactory(sslContext)); // 启动 WebSocket 服务器 server.start(); } catch (Exception ex) { ex.printStackTrace(); } } } ``` 在这个示例中,我们使用 `org.java_websocket` 库来实现 WebSocket 服务器,使用 `com.sun.net.httpserver` 库来创建 HttpsServer。在 `main` 方法中,我们首先加载证书和密钥,然后配置 SSLContext。接着,我们创建了一个 WSS 协议的 WebSocket 服务器,并使用 `DefaultSSLWebSocketServerFactory` 类将 SSLContext 配置到 WebSocketFactory 中。最后,我们启动了 WebSocket 服务器

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

行囊电子商务

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值