Android websocket長連線+點對點訂閱
專案中使用到了websocket長連線+點對點訂閱,部落格記錄下。
長連線通常使用的是名稱叫做STOMP的協議,具體跟伺服器端的開發人員確認即可。
直接貼乾貨:
module build.gradle新增依賴:
compile 'com.github.NaikSoftware:StompProtocolAndroid:1.1.1'
compile 'org.java-websocket:Java-WebSocket:1.3.0'
工程的build.gradle新增:
maven { url "https://jitpack.io" }
長連線通常放在service裡面
核心程式碼:
private void connect() {
mStompClient = Stomp.over(WebSocket.class, WS_URI);
mStompClient.connect();
mStompClient.lifecycle().subscribe(new Action1<LifecycleEvent>() {
@Override
public void call(LifecycleEvent lifecycleEvent) {
//關注lifecycleEvent的回撥來決定是否重連
switch (lifecycleEvent.getType()) {
case OPENED:
mNeedConnect = false;
Log.d(TAG, "forlan debug stomp connection opened");
break;
case ERROR:
mNeedConnect = true;
Log.e(TAG, "forlan debug stomp connection error is ", lifecycleEvent.getException());
break;
case CLOSED:
mNeedConnect = true;
Log.d(TAG, "forlan debug stomp connection closed");
break;
}
}
});
registerStompTopic();
}
//建立長連線,伺服器端沒有心跳機制的情況下,啟動timer來檢查長連線是否斷開,如果斷開就執行重連
private void createStompClient() {
connect();
mTimer.schedule(new TimerTask() {
@Override
public void run() {
Log.d(TAG, "forlan debug in timer ======================");
if (mNeedConnect && NetworkUtil.isNetworkConnected(getApplicationContext())) {
mStompClient = null;
connect();
Log.d(TAG, "forlan debug start connect WS_URI");
}
}
}, RECONNECT_TIME_INTERVAL, RECONNECT_TIME_INTERVAL);
}
//點對點訂閱,根據使用者名稱來推送訊息
private void registerStompTopic() {
mStompClient.topic("/user/" + getUserAccount() + "/msg").subscribe(new Action1<StompMessage>() {
@Override
public void call(StompMessage stompMessage) {
Log.d(TAG, "forlan debug msg is " + stompMessage.getPayload());
}
});
}
點對點訂閱的思想:啟動長連線,針對特定的使用者推送訊息。捋明白後還是很簡單明瞭。
感謝大神的文章,讓我豁然開朗
https://blog.csdn.net/soslinken/article/details/53021510
=========================================
分割線來啦,2018.12.18更新
有同學反映topic訂閱之後沒有回撥call方法。老夫特意從伺服器端推送了訊息到之前做的apk端,發現沒有問題。幾經討論,後來此同學發現是topic訂閱的引數不正確,需要加入自己的連結。如下:
mStompClient.topic("/queue/"+“自己的連結”).subscribe(topicMessage -> {
Log.d("listenStomp", topicMessage.getPayload());
});
//要這種形式才能正常log,這麼寫就能使用成功,迷之問題。
看來是跟伺服器端STOMP版本有關係。老夫之前跟同事聯調的時候,比較幸運,並未遇到此問題。
特意更新記錄下這個坑。具體請點選以下連結
https://github.com/NaikSoftware/StompProtocolAndroid/issues/130
相關文章
- 智對 Android 訂閱難點:教你如何應對工作中 10 種常見訂閱問題Android
- Websocket 突破最大長連線Web
- Linux測試點對點連線速度工具Linux
- Redis 訂閱 + swoole_websocket 推送RedisWeb
- websocket連線Web
- 使用websocket連線(對接)asp.net core signalrWebASP.NETSignalR
- WebSocket 是什麼原理?為什麼可以實現持久連線?有點懵!!!Web
- WebSocket斷線重連Web
- WebSocket 的故事(四)—— Spingboot 中,如何利用 WebSocket 和 STOMP 快速構建點對點的訊息模式(2)Webboot模式
- WebSocket的故事(三)—— Springboot中,如何利用WebSocket和STOMP快速構建點對點的訊息模式(1)WebSpring Boot模式
- 輪詢、長輪詢、短連線、長連線區別對比
- clash 實現訂閱節點與規則的分離
- 雨露均沾的OkHttp—WebSocket長連線的使用&原始碼解析HTTPWeb原始碼
- Android 架構之長連線技術Android架構
- Headscale實現點對點直連異地組網
- MQTT 客戶端出現連線訂閱等問題時如何排查?MQQT客戶端
- 點對點
- websocket連線mina被拒絕Web
- 體驗用yarp連線websocketWeb
- 點到直線的距離,垂足,對稱點,兩點所成的直線方程
- Android 長連線初體驗(基於netty)AndroidNetty
- 長連線閘道器技術專題(六):石墨文件單機50萬WebSocket長連線架構實踐Web架構
- netty系列之:讓TCP連線快一點,再快一點NettyTCP
- Hyperf搭建websocket叢集專案(透過redis釋出訂閱)WebRedis
- 軟連線、硬連結 和 i節點(inode)
- angular使用 websocket,少點套路,多一點真誠AngularWeb
- Vue+WebSocket 實現頁面實時重新整理長連線VueWeb
- 對釋出-訂閱者模式的解析模式
- [譯] Go 實現百萬 WebSocket 連線GoWeb
- Django使用channels實現Websocket連線DjangoWeb
- 使用Docker Context連線遠端節點DockerContext
- 慢查詢、pipline、釋出訂閱、 bitmap點陣圖、 hyperloglog、geo、持久化持久化
- 長連線和短連線
- Android技能樹 — Rxjava取消訂閱小結(2):RxLifeCycleAndroidRxJava
- 以太坊公鏈節點連線節點超時問題排查
- 3.2點對點ppp
- 想要流暢體驗 TDengine 3.0 資料訂閱功能?要點都在這裡
- openGauss 訂閱