尝试在应用程序中实现此功能。松弛RTM在呼叫rtm之后。首先,我得到JSON-response并提取wss url。在它之后,以下文档我需要打开websocket。尝试了两个库
compile 'com.koushikdutta.async:androidasync:2.+'
compile 'org.java-websocket:Java-WebSocket:1.3.0'
第一次给出TimeoutException,第二次进入onClose方法,i = -1, b = true (onError或onOpen不被调用,见下面的代码)。
connection = (HttpURLConnection) new URL(getQuery(URL + "rtm.start",
new Pair<>("token", TOKEN))).openConnection();
final String response = readIs(connection.getInputStream());
JSONObject jResponse = new JSONObject(response);
String uri = (String) jResponse.get("url");
与Java-WebSocket我已经尝试过这个代码(标准从github上的例子):
connectWebSocket(uri);
private void connectWebSocket(String uriStr) {
URI uri;
try {
uri = new URI(uriStr);
} catch (URISyntaxException e) {
e.printStackTrace();
return;
}
log(uri.toString());
log(uri.toASCIIString());
mWebSocketClient = new WebSocketClient(uri) {
@Override
public void onOpen(ServerHandshake serverHandshake) {
log("Opened");
mWebSocketClient.send("Hello from " + Build.MANUFACTURER + " " + Build.MODEL);
}
@Override
public void onMessage(String s) {
log(s);
}
@Override
public void onClose(int i, String s, boolean b) {
log("Closed " + s + " " + b + " number: " + i);
}
@Override
public void onError(Exception e) {
log("Error " + e.getMessage());
}
};
mWebSocketClient.connect();
}
正如我上面所说的,只有onClose被调用。
与AndroidAsync尝试标准代码从例子太:
AsyncHttpClient.getDefaultInstance().websocket(uri, "wss", (ex, webSocket) -> {
if (ex != null) {
log(ex.getMessage());
return;
}
webSocket.send("a string");
});
我以前从未在android上使用过websockets,我不明白我做错了什么。谢谢你的帮助。
JSON中的Url类型为
wss://ms156.slack-msgs.com/websocket/LYBUMUtG-bqj9HkKwEB5Yk_DCyPeRbnZ4viUJYHzrzJnLr-M74d46IQ9khTF8rik-v6ckJ4hqXPRi666hyPR6pismYBZBsggJUade3LOARc=
最后我的同事成功地使用OkHttp打开了这个套接字。如果有人感兴趣-测试项目的代码提供如下:http://pastebin.com/3YhLjAn7有趣的是——最后我们决定不使用RTM,因为一个连接的负载太高了——您从所有聊天中接收事件,并且没有办法仅为一个特定的设置过滤器。