websocket 使用wss协议 出现 Unrecognized SSL message, plaintext connection
时间: 2024-01-11 08:00:42 浏览: 31
这个问题通常是因为客户端和服务器之间的 SSL/TLS 握手失败导致的。可能有以下几种原因:
1. 服务器没有配置 SSL/TLS 证书或证书不正确。
2. 客户端正在使用错误的 WebSocket URL。
3. 客户端和服务器之间的网络连接存在问题。
为了解决这个问题,你可以尝试以下几个步骤:
1. 确认你正在使用正确的 WebSocket URL,包括正确的协议(wss://)和正确的端口号(通常是 443)。
2. 检查服务器是否已正确配置 SSL/TLS 证书。你可以使用 OpenSSL 命令行工具来测试 SSL/TLS 连接。例如,可以使用以下命令测试 SSL 连接:`openssl s_client -connect yourserver.com:443`。
3. 如果 SSL/TLS 连接测试失败,可能是因为证书不正确或客户端和服务器之间的网络连接存在问题。尝试使用其他设备或网络连接测试客户端和服务器之间的连接是否存在问题。
相关问题
怎么通过java代码在服务器端websocket使用WSS 协议
在 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 服务器。
uni-app能使用wss协议的websocket吗
是的,uni-app可以使用wss协议的WebSocket。uni-app是一个跨平台的应用开发框架,它支持在多个平台上构建应用,包括Web、iOS、Android等。在uni-app中,可以使用uni-socket.io插件或者原生的WebSocket API来创建WebSocket连接。
uni-socket.io是一个基于Socket.IO的插件,它提供了对WebSocket的封装和简化。通过uni-socket.io插件,你可以在uni-app中轻松地创建和管理WebSocket连接,并且可以选择使用wss协议来进行加密通信。
如果你选择使用原生的WebSocket API,也可以在uni-app中使用wss协议。WebSocket API提供了connect方法来创建WebSocket连接,并且可以通过指定wss://开头的URL来使用wss协议。
无论是使用uni-socket.io插件还是原生的WebSocket API,只要服务器支持wss协议,uni-app就可以与服务器进行安全的加密通信。