溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解析SpringMVC4.1服務器端推送實現(xiàn)過程

發(fā)布時間:2021-10-13 15:01:09 來源:億速云 閱讀:120 作者:柒染 欄目:編程語言

這篇文章給大家介紹如何解析SpringMVC4.1服務器端推送實現(xiàn)過程,內(nèi)容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

服務器端推送

SSE(server send event)是一種服務器端向瀏覽器推送消息的技術,而不是我們常規(guī)的瀏覽器像server請求然后響應;  當我們需要使用server向瀏覽器主動推送數(shù)據(jù)的時候,請考慮使用該項技術,而不是考慮具有雙向通訊功能的websocket;  以前我們用ajax輪詢server也能實現(xiàn),服務器負擔大;  sse原理是向server請求一次后,server會掛住請求不放(此時瀏覽器里請求狀態(tài)是pending),等有數(shù)據(jù)后才返回給瀏覽器,然后再發(fā)起下一次請求,以此類推;  所有主流瀏覽器均支持服務器發(fā)送事件,除了 Internet Explorer(6,7,8,9);

示例

服務器推送控制器

package com.wisely.web;import java.util.Random;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.ResponseBody;@Controllerpublic class SSEController {  //注意produces="text/event-stream"  @RequestMapping(value="/push",produces="text/event-stream")  public @ResponseBody String push(){     Random r = new Random();     try {         Thread.sleep(5000);     } catch (InterruptedException e) {         e.printStackTrace();     }     return "data:Testing 1,2,3" + r.nextInt() +"\n\n";  }}

頁面代碼

<p id="msg_from_server"></p><script type="text/javascript" src="<c:url value="/js/jquery.js" />"></script><script type="text/javascript">if (!!window.EventSource) {    var source = new EventSource('push'); //為http://localhost:8080/testSpringMVC/push    s='';    source.addEventListener('message', function(e) {      s+=e.data+"<br/>"      $("#msg_from_server").html(s);    });    source.addEventListener('open', function(e) {      console.log("連接打開.");    }, false);    source.addEventListener('error', function(e) {      if (e.readyState == EventSource.CLOSED) {        console.log("連接關閉");      } else {        console.log(e.readyState);        }    }, false);  } else {      console.log("沒有sse");  }</script>

關于如何解析SpringMVC4.1服務器端推送實現(xiàn)過程就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI