网络套接字握手.从ws到wss



我正在开发一个应用程序一段时间,最近我在应用程序上附加了一个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。

相关内容

  • 没有找到相关文章

最新更新