Websocket:是否可以从程序中了解onClose被调用的原因

时间:2013-04-15 03:34:21

标签: websocket jetty

我有一个示例WebSocket程序,下面可以正常工作

当用户关闭浏览器或有任何例外或任何断开连接时,onClose方法是 被称为

我的问题是,是否可以从程序中了解onClose被调用的原因是什么? 请分享您的观点,感谢您阅读。

public class Html5Servlet extends WebSocketServlet {

    private AtomicInteger index = new AtomicInteger();

    private static final List<String> tickers = new ArrayList<String>();
    static{
        tickers.add("ajeesh");
        tickers.add("peeyu");
        tickers.add("kidillan");
        tickers.add("entammo");
    }

    /**
     * 
     */
    private static final long serialVersionUID = 1L;

    public WebSocket doWebSocketConnect(HttpServletRequest req, String resp) {
        //System.out.println("doWebSocketConnect");
        return new StockTickerSocket();
    }
    protected String getMyJsonTicker() throws Exception{
        return "";
    }
    public class StockTickerSocket implements WebSocket.OnTextMessage{
        private Connection connection;
        private Timer timer; 


        @Override
        public void onClose(int arg0, String arg1) {
            System.out.println("onClose called!"+arg0);
        }

        @Override
        public void onOpen(Connection connection) {
            //System.out.println("onOpen");
            this.connection=connection;
            this.timer=new Timer();
        }

        @Override
        public void onMessage(String data) {
            //System.out.println("onMessage");
            if(data.indexOf("disconnect")>=0){
                connection.close();
                timer.cancel();
            }else{
                sendMessage();

            }           
        }




        public void disconnect() {

            System.out.println("disconnect called");
        }

        public  void onDisconnect()
        {
            System.out.println("onDisconnect called");
        }


        private void sendMessage() {

            if(connection==null||!connection.isOpen()){
                //System.out.println("Connection is closed!!");
                return;
            }
            timer.schedule(new TimerTask() {

                    @Override
                    public void run() {
                        try{
                            //System.out.println("Running task");
                            connection.sendMessage(getMyJsonTicker());
                        }
                        catch (IOException e) {
                            e.printStackTrace();
                        } catch (Exception e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }
                    }
                }, new Date(),5000);
        }

    }
}

1 个答案:

答案 0 :(得分:2)

onClose的签名如下......

    @Override
    public void onClose(int closeCode, String closeReason) {
        System.out.println("onClose called - statusCode = " + closeCode);
        System.out.println("                 reason     = " + closeReason);
    }

int closeCoderegistered Close Status Codes中的任何一个。

String closeReason是可选的(per protocol spec)关闭原因消息。