【发布时间】:2017-09-21 11:53:13
【问题描述】:
我用这个code 用java 编写了websocket 客户端。这是一个安全的插座。与目的地的连接建立良好,但未调用 onMessage。
当我在 java 脚本中编写相同的东西时,它正在工作并且能够得到响应。
请检查我的代码并告知我在这里遗漏了什么。
我的代码:
@ClientEndpoint
public class MyClientEndpoint {
@SuppressWarnings("unchecked")
@OnOpen
public void onOpen(Session session) {
System.out.println("Connected to endpoint: " + session.getBasicRemote());
try {
JSONObject obj = new JSONObject();
obj.put("subscribe", URLEncoder.encode("xxxxxxx","UTF-8"));
String msg = obj.toJSONString();
System.out.println("Sending message to endpoint: " + msg);
session.getBasicRemote().sendText(msg);
} catch (Exception ex) {
Logger.getLogger(MyClientEndpoint.class.getName()).log(Level.SEVERE, null, ex);
}
}
@OnMessage
public void onMessage(String message) {
System.out.println("Received message in client: " + message);
Client.messageLatch.countDown();
}
public class Client {
final static CountDownLatch messageLatch = new CountDownLatch(1);
public static void main(String[] args) {
try {
WebSocketContainer container = ContainerProvider.getWebSocketContainer();
String uri = "wss://api.....";
System.out.println("Connecting to:: " + uri);
container.connectToServer(MyClientEndpoint.class, URI.create(uri));
messageLatch.await(10, TimeUnit.SECONDS);
} catch (DeploymentException | InterruptedException | IOException ex) {
Logger.getLogger(Client.class.getName()).log(Level.SEVERE, null, ex);
}
}
}
【问题讨论】:
-
您的
@OnMessage中可能缺少Session session参数。签名应该是public void myMethod(Session session, String message); -
尝试将 Session 会话作为该方法的第一个参数,但仍然无法正常工作。
标签: java websocket java-websocket