1. 程式人生 > >服務端推送常用技術

服務端推送常用技術

服務端推送常用技術

  1. 客戶端輪詢的方式:通過ajax定時拉取,setinterval
  2. 服務端主動推送:webSocket,全雙工的,本質是一個額外的tcp連線,建立和關閉時握手使用http協議,其它資料傳輸不使用http協議,更加複雜一些,適用於需要進行復雜雙向資料通訊的場景(推薦)
  3. 服務端主動推送,SSE(Server Send Event),html5新標準,用於從服務端實時推送資料到瀏覽器端,直接建立在當前的http連線上,本質上是保持一個http長連線,輕量協議,主要應用於簡單的伺服器資料推送的場景,使用伺服器推送場景

使用springboot實現服務端主動推送


步驟:

  1. 在請求的方法@Requestmapping註解裡面的屬性項裡面加上屬性:produces= “text/event-stream;charset=UTF-8” (produces的作用是指定返回值型別,不但可以設定返回值型別還可以設定返回的字元編碼)
 @GetMapping(value = "getData",produces = "text/event-stream;charset=UTF-8")
    public String getStockMarket(){
        try {
            Thread.sleep(1000);
            //任務
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return "data:當前股票行情為" + Math.random();
    }
  1. 在resources預設載入的目錄建立一個頁面,public/static/resources目錄都可以,注意:不在預設載入的目錄的建立html頁面,可以使用引入typemelf,在controller中跳轉回該html頁面中,這只是其中的一種方案

index.html頁面內容

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script type="text/javascript">
        var source = new EventSource('/getData');
        source.onmessage = function (event) {
            console.info(event.data);
            document.getElementById('result').innerText=event.data;
        }
    </script>
</head>
<body>
模擬股票行情
<h3>股票市場</h3>
<div id="result"></div>
</body>
</html>
  1. 效果在這裡插入圖片描述