我正在开发一个应用程序一段时间,最近我在应用程序上附加了一个SSL证书(它不是自签名的;它是由Comodo签名的,所以问题不会从这里发生)。很久以前,我在我的Java Glassfish服务器上实现了WebSocket端点,并且我正在将其与javascript一起使用。我一直通过http成功使用WebSocket,直到现在,当我转移到https时。
让我们看一下我使用的代码片段:
服务器终结点:
@ServerEndpoint(value = "/ws/chat",
encoders = ChatMessageEncoder.class,
decoders = ChatMessageDecoder.class)
public class ChatEndpoint {
@OnOpen
public void open(final Session session) {
// stuff happenin'
}
@OnMessage
public void onMessage(final Session session) {
// stuff happenin' }
@OnError
public void onError(Throwable t) {
t.printStackTrace();
System.out.println("error");
}
@OnClose
public void onClose() {
}
}
客户端连接:
var wsocketPrivate;
function connectToChatserver() {
var serviceLocation = 'wss://<ip>:8080/ws/chat';
$rootScope.wsocketPrivate = new WebSocket(serviceLocation);
$rootScope.wsocketPrivate.onmessage = onMessageReceived;
};
function onMessageReceived(evt) {
console.log(evt)
};
connectToChatserver();
没有激活 ssl 证书并使用 var serviceLocation = 'ws://<ip>:8080/ws/chat';
(ws 而不是 wss)工作得很好。当我移动到https时,它要求wss(浏览器阻止了我的ws握手,因为它不安全)并移动到wss,发生以下错误:
WebSocket connection to 'wss://<ip>:8080/ws/chat' failed: Error in connection establishment: net::ERR_TIMED_OUT
我做错了什么?你能建议一些测试来了解更多信息吗?
谢谢米哈伊
我终于找到了问题所在。我正在使用nginx前端服务器作为代理。由于某种奇怪的原因,该服务器的默认配置阻止了我的 wss。