为什么握手失败?

时间:2012-04-22 02:49:37

标签: java websocket

我正在使用websocket4j库,我看了一个如何在服务器应用程序中使用它的示例。我从那里获取代码并将其添加到我之前使用原始套接字的当前项目中。无论我使用哪个客户端,我似乎都在获得一个IOExcpetion,说握手失败了。我不知道什么是错误的,因为我从示例服务器(显然应该工作)中获取代码,并且我使用了一个javascript示例客户端来确保它不是客户端的错。这是主要方法。

 public static void main(String args[]){
        BufferedReader b=new BufferedReader(new InputStreamReader(System.in));
        System.out.print("PORT ( default - 1000 ): ");
        int port=1000;
        try{
            port=Integer.parseInt(b.readLine());
        }
        catch(Exception e){
            System.out.println("Wrong format. Using 1000 instead");
            port=1000;
        }
        System.out.println("Server Started. Waiting for connections");
        try{
            WebServerSocket listener=new WebServerSocket(port);
            while(true){
                WebSocket server=listener.accept();
                U413ChatServer connection=new U413ChatServer(server);
                Thread t=new Thread(connection); 
                t.start();
            }
        }
        catch(Exception e){ e.printStackTrace();
        }
    }

而且这是屏幕上的内容

Server Started. Waiting for connections
java.io.IOException: Handshake failed
        at websocket4j.AbstractWebSocket.<init>(Unknown Source)
        at websocket4j.server.WebSocket.<init>(Unknown Source)
        at websocket4j.server.WebServerSocket.accept(Unknown Source)
        at U413ChatServer.main(U413ChatServer.java:55)
Caused by: java.io.IOException: Unexpected header field: Sec-WebSocket-Key: yfOg
xCbblVyY8ARVFyMtOw==
        at websocket4j.server.WebSocket.handshake(Unknown Source)
        at websocket4j.AbstractWebSocket$HandshakeRunner.run(Unknown Source)
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:47
1)
        at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334)
        at java.util.concurrent.FutureTask.run(FutureTask.java:166)
        at java.lang.Thread.run(Thread.java:722)

第55行是:

WebSocket server=listener.accept();

任何帮助都会非常感激

2 个答案:

答案 0 :(得分:1)

您的客户端使用的WebSocket协议与服务器的协议版本不兼容。

服务器实现过时(过期日期:2011年2月17日)WebSocket protocol draft-ietf-hybi-thewebsocketprotocol-latest 而您的客户可能会实现类似RFC6455(标准)的内容。

您应该查看其他实施,例如Netty or the Jetty WebSocketServer

答案 1 :(得分:0)

是的assylias是对的。您正在使用的websocket4j工具包确实已过时,需要两个密钥和令牌值才能生成响应,由于数字除以零异常或流结束异常而失败。