搜尋
首頁Javajava教程WebSocket實作Java後台訊息推播的原理與基礎知識

1.什麼是WebSocket

  WebSocket協定是基於TCP的一種新的網路協定。它實作了瀏覽器與伺服器全雙工(full-duplex)通訊-允許伺服器主動傳送訊息給客戶端。

2.實作原理

  在實作websocket連線過程中,需要透過瀏覽器發出websocket連線請求,然後伺服器發出回應,這個過程通常稱為「握手」 。在 WebSocket API,瀏覽器和伺服器只需要做一個握手的動作,然後,瀏覽器和伺服器之間就形成了一條快速通道。兩者之間就直接可以資料互相傳送。  

3.優點

  在先前的訊息推送機制中,用的都是Ajax 輪詢(polling),在特定的時間間隔由瀏覽器自動發出請求,將伺服器的訊息主動的拉回來,這種方式是非常消耗資源的,因為它本質還是http請求,而且顯得非常笨拙。而WebSocket 在瀏覽器和伺服器完成一個握手的動作,在建立連線之後,伺服器可以主動傳送資料給客戶端,客戶端也可以隨時向伺服器發送資料。

4.WebSocket和Socket的差異

#  1.WebSocket:



    1. ##websocket通訊的建立階段是依賴http協定的。最初的握手階段是http協議,握手完成後就切換到websocket協議,並完全與http協議脫離了。
    2. 建立通訊時,也是由客戶端主動發起連線請求,服務端被動監聽。

    3. 通訊一旦建立連線後,通訊就是「全雙工」模式了。也就是說服務端和客戶端都能在任何時間自由得發送數據,非常適合服務端要主動推送即時數據的業務場景。

    4. 互動模式不再是「請求-應答」模式,完全由開發者自行設計通訊協定。
    5. 通訊的數據是基於「幀(frame)」的,可以傳輸文字數據,也可以直接傳輸二進位數據,效率高。當然,開發者也要考慮封包、拆包、編號等技術細節。
    6.  2.Socket:

#服務端監聽通訊,被動提供服務;客戶端主動向服務端發起連線請求,建立起通訊。

    websocket.close(); 

每一次互動都是:客戶端主動發起請求(request),服務端被動應答(response)。

服務端不能主動向客戶端推送資料。

通訊的資料是基於文字格式的。二進位資料(如圖片等)要利用base64等手段轉換成文字後才能傳輸。

5.WebSocket客戶端:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39
40

41 42 43

44

45

46

47 48 49 50

51

var websocket = 

null;

var host = document.location.host;  var username = "${loginUsername}"

// 取得目前登入人員的userName #  // alert(username)

//判斷目前瀏覽器是否支援WebSocket # if ('WebSocket' in window) { #     

alert("瀏覽器支援Websocket")

    websocket = new WebSocket('ws://'

host '/mm-dorado/webSocket/'

username); 

### ######} ######else### ###{ ####### ######    ######alert(######'目前瀏覽器 Not support websocket'######) ####### ######} ####### ### ###

//連線發生錯誤的回呼方法 

#

websocket.onerror = function() { 

#

  alert("WebSocket連線發生錯誤")

   setMessageInnerHTML("WebSocket連線發生錯誤"); 

##

};  

   

#

//連線成功建立的回呼方法 

#

websocket.onopen = function() {

  alert("WebSocket連線成功"

   setMessageInnerHTML(#"WebSocket連線成功"); 

#

#

   

#

//接收到訊息的回呼方法 

#

websocket.onmessage = function(event) {

    alert("接收到訊息的回呼方法"

    alert("這是背景推送的訊息:" event.data);

##

     websocket.close();

    alert(

"webSocket已關閉!"

)

#

#   

 

# //連接關閉的回呼方法 

# websocket.onclose = function() { 

    

setMessageInnerHTML("WebSocket連線關閉"

); ##

#   

 

#

//監聽窗口關閉事件,當窗口關閉時,主動去關閉websocket連接,防止連接還沒斷開就關閉窗口,server端會拋異常。 #

window.onbeforeunload = function() { #     

closeWebSocket();  #    # //關機WebSocket連線 

# function closeWebSocket() { 

### ######} ####### ### ### ######//將訊息顯示在網頁上###### ######    ######function setMessageInnerHTML(innerHTML) {###### ######        ######document.getElementById(######'message'######).innerHTML = innerHTML  #######'
' ######;###### ######    ######}###### ### ##########

  6.WebSocket服務端(java後台):

    1.核心類別:

        } 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85
86

87 88

89

90

91 92

93

package

 

com.mes.util;  

import

 

java.io.IOException;# import

 

java.util.Map; import

 

java.util.concurrent.ConcurrentHashMap;  

import javax.websocket.OnClose;

import javax.websocket.OnError;

import javax.websocket.OnMessage;

import javax.websocket.OnOpen;

import

 

javax.websocket.Session; import

 

javax.websocket.server.PathParam; import

 

javax.websocket.server.ServerEndpoint;

  import

 

org.springframework.stereotype.Component;

import org.springframework.stereotype.Service;

  import com.google.gson.JsonObject;#

 

import net.sf.json.JSONObject;# @ServerEndpoint

("/webSocket/{username}")       public class WebSocket { 

#         private static int onlineCount = 0#1

##

        private static 

Map clients = 

#new ##ConcurrentHashMap&T; , WebSocket>();          

private Session session; 

#         private

 

String username; #            #         @OnOpen #         publicvoid onOpen(

#@PathParam#(

#" username") String username, Session session) #throws IOException { 

#        #             

this.username = username; 

############################################################################ ######            ######this######.session = session; ####################################################################################################### ######              ### #### ######            #######addOnlineCount(); #######

            clients.put(使用者名稱, ##this#);#

            System.out.println("連線"#);已#

        

      #

        @OnClose #

        public## void onClose() 拋出IOException { 

 ##. ##             

#clients.remove(使用者名稱);

            

subOnlineCount();

        

      

#         

@OnMessage

 #         public## void onMessage(String message) ## 

IO

##       

#             #JSONObject jsonTo = JSONObject.fromObject(message);

            String mes = (String) jsonTo.get(##"訊息"#);

            所

##》之一之一             if(!jsonTo.get(

#"To").equals(# # 「全部」######)){ #####                 sendMessageTo(mes, jsonTo.get(

#"To"

).toString())); ###########                 sendMessageAll(

#"給擁有者"

#);             

        

      #

        

@OnError 

#

        public## 

void

 onError(會話會話,可拋出錯誤){              error.printStackTrace();

        

      #

        

public## 

void

 sendMessageTo(String message, String To) throws #              // session.getBasicRemote().sendText(message);

             //session.getAsyncRemote().sendText(message);

            for(WebSocket 項目:clients.values()) { 

                if(item.username.equals(To) ) 

(item.username.equals(To) ) 

##################################################################################################################'###### ######                    ######item.session.getAsyncRemote().sendText(message); ######

            

        

          

        public## #void sendMessageAll(String message)  throws#> ##

            

for(WebSocket 項目:clients.values()) { 

                

item.session.getAsyncRemote().sendText(訊息);

            

        

      

#

        

publicstatic synchronized int getOnlineCount() {#o  

getOnlineCount() {#o

#C

            #return

onlineCount;                #

        publicstatic

 

synchronized #void addOnlineCount(

# ### #

            

WebSocket.onlineCount ;

               #

        

publicstatic 

synchronized

 #void ## #             

WebSocket.onlineCount--;

               #         

publicstatic synchronized Map getClients() { 

#             #返回

 

顧客;

}"To",invIO.getIoEmployeeUid());

2.在自己程式碼中的呼叫:

#1
2

3 4 5

WebSocket ws = newWebSocket();

JSONObject jo = newJSONObject();# jo.put(

"message""這是背景回傳的訊息!");

jo.put(

#### ######ws.onMessage(jo.toString());###### ### ##########

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

<!-- webSocket 開始-->

#

#

    <groupid>javax.websocket</groupid>

#

    <artifactid>javax.websocket-api</artifactid>

    1.1版本>

    提供範圍>

#

依賴>

#

 

##

#

    <groupid>javax</groupid>

    <artifactid>javaee-api</artifactid>

#

    7.0版本>

    提供範圍>

#

依賴>

#

<!-- webSocket 結束-->

相關文章:

##Java中websocket訊息本體

一個基於WebSocket的WEB訊息本體框架

相關影片:


Websocket影片教學#

以上是WebSocket實作Java後台訊息推播的原理與基礎知識的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何將Maven或Gradle用於高級Java項目管理,構建自動化和依賴性解決方案?如何將Maven或Gradle用於高級Java項目管理,構建自動化和依賴性解決方案?Mar 17, 2025 pm 05:46 PM

本文討論了使用Maven和Gradle進行Java項目管理,構建自動化和依賴性解決方案,以比較其方法和優化策略。

如何使用適當的版本控制和依賴項管理創建和使用自定義Java庫(JAR文件)?如何使用適當的版本控制和依賴項管理創建和使用自定義Java庫(JAR文件)?Mar 17, 2025 pm 05:45 PM

本文使用Maven和Gradle之類的工具討論了具有適當的版本控制和依賴關係管理的自定義Java庫(JAR文件)的創建和使用。

如何使用咖啡因或Guava Cache等庫在Java應用程序中實現多層緩存?如何使用咖啡因或Guava Cache等庫在Java應用程序中實現多層緩存?Mar 17, 2025 pm 05:44 PM

本文討論了使用咖啡因和Guava緩存在Java中實施多層緩存以提高應用程序性能。它涵蓋設置,集成和績效優勢,以及配置和驅逐政策管理最佳PRA

如何將JPA(Java持久性API)用於具有高級功能(例如緩存和懶惰加載)的對象相關映射?如何將JPA(Java持久性API)用於具有高級功能(例如緩存和懶惰加載)的對象相關映射?Mar 17, 2025 pm 05:43 PM

本文討論了使用JPA進行對象相關映射,並具有高級功能,例如緩存和懶惰加載。它涵蓋了設置,實體映射和優化性能的最佳實踐,同時突出潛在的陷阱。[159個字符]

Java的類負載機制如何起作用,包括不同的類載荷及其委託模型?Java的類負載機制如何起作用,包括不同的類載荷及其委託模型?Mar 17, 2025 pm 05:35 PM

Java的類上載涉及使用帶有引導,擴展程序和應用程序類負載器的分層系統加載,鏈接和初始化類。父代授權模型確保首先加載核心類別,從而影響自定義類LOA

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。