ionic+cordova基於websocket實現的實時通報提醒功能

app接收後臺發出的請求,並通過狀態欄提示用戶有新的消息,這裏首先要解決的就是前後端如何互聯,像pc端的應用,一般會採用前端定時請求後臺,但如果要app定時去訪問後臺的話,對用戶來說並不友好,這會消耗用戶大量的移動流量,移動端最好的方式就是後臺主動向app推送信息,h5提供了一種比較好的方式就是websocket,用戶打開app後,向後臺發出請求,後臺相應後,就可以實時向前端推送信息了,而無需app再次去訪問,具體前後臺實現如下:

package com.wavefax.wavefax51.openapi.servlet;

import java.io.IOException;
import java.util.concurrent.CopyOnWriteArraySet;
 
import javax.websocket.OnClose;
import javax.websocket.OnError;
import javax.websocket.OnMessage;
import javax.websocket.OnOpen;
import javax.websocket.Session;
import javax.websocket.server.ServerEndpoint;

/**
 *
 * @author Administrator
 */
@ServerEndpoint("/websocket")
public class WebSocket {
    //靜態變量,用來記錄當前在線連接數。應該把它設計成線程安全的。
    private static int onlineCount = 0;
     
    //concurrent包的線程安全Set,用來存放每個客戶端對應的MyWebSocket對象。若要實現服務端與單一客戶端通信的話,可以使用Map來存放,其中Key可以爲用戶標識
    private static CopyOnWriteArraySet<WebSocket> webSocketSet = new CopyOnWriteArraySet<WebSocket>();
     
    //與某個客戶端的連接會話,需要通過它來給客戶端發送數據
    private Session session;
     
    /**
     * 連接建立成功調用的方法
     * @param session  可選的參數。session爲與某個客戶端的連接會話,需要通過它來給客戶端發送數據
     */
    @OnOpen
    public void onOpen(Session session){
        this.session = session;
        webSocketSet.add(this);     //加入set中
        addOnlineCount();           //在線數加1
        System.out.println("有新連接加入!當前在線人數爲" + getOnlineCount());
    }
     
    /**
     * 連接關閉調用的方法
     */
    @OnClose
    public void onClose(){
        webSocketSet.remove(this);  //從set中刪除
        subOnlineCount();           //在線數減1    
        System.out.println("有一連接關閉!當前在線人數爲" + getOnlineCount());
    }
     
    /**
     * 收到客戶端消息後調用的方法
     * @param message 客戶端發送過來的消息
     * @param session 可選的參數
     */
    @OnMessage
    public void onMessage(String message, Session session) {
        System.out.println("來自客戶端的消息:" + message);
         
        //羣發消息
        for(WebSocket item: webSocketSet){             
            try {
                item.sendMessage(message);
            } catch (IOException e) {
                e.printStackTrace();
                continue;
            }
        }
    }
     
    /**
     * 發生錯誤時調用
     * @param session
     * @param error
     */
    @OnError
    public void onError(Session session, Throwable error){
        System.out.println("發生錯誤");
        error.printStackTrace();
    }
     
    /**
     * 這個方法與上面幾個方法不一樣。沒有用註解,是根據自己需要添加的方法。
     * @param message
     * @throws IOException
     */
    public void sendMessage(String message) throws IOException{
        this.session.getBasicRemote().sendText(message);
        //this.session.getAsyncRemote().sendText(message);
    }
 
    public static synchronized int getOnlineCount() {
        return onlineCount;
    }
 
    public static synchronized void addOnlineCount() {
        WebSocket.onlineCount++;
    }
     
    public static synchronized void subOnlineCount() {
        WebSocket.onlineCount--;
    }    
}

在app發請求的代碼如下:

websocket = null;

var websocketAddress = 'ws://'+ url

//判斷當前瀏覽器是否支持WebSocket
if('WebSocket' in window){
    websocket = new WebSocket(websocketAddress);
}
else{
    alert('Not support websocket')
}

//連接發生錯誤的回調方法
websocket.onerror = function(){
    //notificationReminder("error");
};

//連接成功建立的回調方法
websocket.onopen = function(event){
    console.log(event);
}

//接收到消息的回調方法
websocket.onmessage = function(event){
    $scope.notificationReminder(event.data);
}

//連接關閉的回調方法
websocket.onclose = function(){
    //notificationReminder("close");
}

//監聽窗口關閉事件,當窗口關閉時,主動去關閉websocket連接,防止連接還沒斷開就關閉窗口,server端會拋異常。
window.onbeforeunload = function(){
    websocket.close();
}

//發送消息
$scope.send = function(){
    websocket.send(localStorageService.get('UserID'));
}
$scope.closeWebSocket = function(){
    websocket.close();
}


前後端互聯成功後,要做就是前端接收到後臺發來的信息後,如何顯示在狀態欄上,提示用戶,這裏主要用到cordova提供的插件,首先安裝cordova-plugin-local-notifications,然後在js配置好如下就可以了:

狀態欄通報提醒
$scope.notificationReminder = function(faxInfo){
    cordova.plugins.notification.local.add({  
        id: id,
        title: '',  
        text: '',  
        at: new Date().getTime(),  
        //badge: 2,  
        autoClear: true,//默認值  
        sound: 'res://platform_default',//默認值  
        icon: 'res://ic_popup_reminder', //默認值  
        ongoing: false  //默認值  
    });
} 


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章