対向のサーバが落ちているとき。
素直にハンドシェイクできないという。まぁ、そのまんま。
7 20, 2013 5:43:29 午後 jp.co.epea.firstfxclient.SampleController$TwitterCheckService$1 call SEVERE: null javax.websocket.DeploymentException: Handshake response not received. at org.glassfish.tyrus.client.ClientManager.connectToServer(ClientManager.java:300) at org.glassfish.tyrus.client.ClientManager.connectToServer(ClientManager.java:172) at jp.co.epea.firstfxclient.SampleController$TwitterCheckService$1.call(SampleController.java:65) at jp.co.epea.firstfxclient.SampleController$TwitterCheckService$1.call(SampleController.java:1) at javafx.concurrent.Task$TaskCallable.call(Task.java:1259) at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334) at java.util.concurrent.FutureTask.run(FutureTask.java:166) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) at java.lang.Thread.run(Thread.java:724)
URI clientURI = new URI(“ws://localhost:8080/first/hellohoge/”);
みたいにURLが間違っている場合。
Handshake errorというやつとスタックとレースにレスポンスコードが返ってくる。
この例だと存在しないパスなので404が返っているけど、WebsocketじゃないただのHTMLだとUpdate Protocolの時に失敗しているので(?)200が返ってくる。
なお、パスの指定時は最後の”/(スラッシュ)”も厳密に見る模様。
7 20, 2013 8:46:51 午後 jp.co.epea.firstfxclient.SampleController$TwitterCheckService$1 call SEVERE: null javax.websocket.DeploymentException: Handshake error. at org.glassfish.tyrus.client.ClientManager.connectToServer(ClientManager.java:285) at org.glassfish.tyrus.client.ClientManager.connectToServer(ClientManager.java:172) at jp.co.epea.firstfxclient.SampleController$TwitterCheckService$1.call(SampleController.java:65) at jp.co.epea.firstfxclient.SampleController$TwitterCheckService$1.call(SampleController.java:1) at javafx.concurrent.Task$TaskCallable.call(Task.java:1259) at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:334) at java.util.concurrent.FutureTask.run(FutureTask.java:166) at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615) at java.lang.Thread.run(Thread.java:724) Caused by: org.glassfish.tyrus.websockets.HandshakeException: Response code was not 101: 404 at org.glassfish.tyrus.websockets.HandShake.validateServerResponse(HandShake.java:314) at org.glassfish.tyrus.websockets.draft06.HandShake06.validateServerResponse(HandShake06.java:98) at org.glassfish.tyrus.container.grizzly.WebSocketFilter.handleClientHandShake(WebSocketFilter.java:368) at org.glassfish.tyrus.container.grizzly.WebSocketFilter.handleHandshake(WebSocketFilter.java:353) at org.glassfish.tyrus.container.grizzly.WebSocketFilter.handleRead(WebSocketFilter.java:274) at org.glassfish.grizzly.filterchain.ExecutorResolver$9.execute(ExecutorResolver.java:119) at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain.java:288) at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:206) at org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:136) at org.glassfish.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:114) at org.glassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77) at org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:837) at org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent(AbstractIOStrategy.java:113) at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:115) at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access$100(WorkerThreadIOStrategy.java:55) at org.glassfish.grizzly.strategies.WorkerThreadIOStrategy$WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:135) at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:565) at org.glassfish.grizzly.threadpool.AbstractThreadPool$Worker.run(AbstractThreadPool.java:545) ... 1 more Connection had closed.
ちなみに、エラーログをはいているのはSampleController#createTaskの中にあるキャッチ節。
@Override protected Task createTask() { Task<Void> task = new Task<Void>() { @Override protected Void call() throws Exception { messageLatch = new CountDownLatch(1); try { URI clientURI = new URI("ws://localhost:8080/first/hellohoge/"); ClientManager cliContainer = org.glassfish.tyrus.client.ClientManager.createClient(); cliContainer.connectToServer(new TwitterClient(table), clientURI); messageLatch.await(1, TimeUnit.SECONDS); } catch (DeploymentException | URISyntaxException | InterruptedException ex) { Logger.getLogger(SampleController.class.getName()).log(Level.SEVERE, null, ex); } return null; } }; return task; }
下の@OnErrorは通らずに、@OnClose(前のログだと緑字部分)で終わるので注意。
@OnClose public void closeConnection(Session session) { System.out.println("Connection had closed."); } @OnError public void onError(Session session,Throwable t) { System.out.println("error"); t.printStackTrace(); }
javafx.concurrent.Taskの使い方次第でもっとハンドリングできそうな気がする。
とりあえず参考になりそうなサイト