一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Spring Boot 整合單機websocket的步驟 附github源碼

Spring Boot 整合單機websocket的步驟 附github源碼

2022-02-12 15:13jeremylai Java教程

websocket 是一個通信協議,通過單個 TCP 連接提供全雙工通信,這篇文章主要介紹了Spring Boot 整合單機websocket的步驟(附github源碼),需要的朋友可以參考下

websocket 概念

websocket 是一個通信協議,通過單個 TCP 連接提供全雙工通信。websocket 連接成功后,服務端和客戶可以進行雙向通信。不同于 http 通信協議需要每次由客戶端發起,服務響應到客戶端。
websocket 相對輪詢也能節約帶寬,并且能實時的進行通信。

整合步驟

1. 添加 maven 依賴

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-websocket</artifactId>
    <version>2.1.3.RELEASE</version>
</dependency>
<dependency>
        <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-freemarker</artifactId>
    <version>2.1.3.RELEASE</version>
</dependency>

添加web、websocket和freemarker依賴。

2. 使用 ServerEndpointExporter 創建 bean

這個 bean 會自動注冊聲明 @ServerEndpoint 注解聲明的 websocket endpoint,使用springboot自帶tomcat啟動需要該配置,使用獨立 tomcat 則不需要該配置。

?
1
2
3
4
5
6
7
8
@Configuration
public class WebSocketConfig {
    //tomcat啟動無需該配置
    @Bean
    public ServerEndpointExporter serverEndpointExporter() {
        return new ServerEndpointExporter();
    }
}

3. 創建服務端端點 (ServerEndpoint)

?
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
@Component
@ServerEndpoint(value = "/message")
@Slf4j
public class WebSocket {
 
    private static Map<String, WebSocket> webSocketSet = new ConcurrentHashMap<>();
 
    private Session session;
 
    @OnOpen
    public void onOpen(Session session) throws SocketException {
        this.session = session;
        webSocketSet.put(this.session.getId(),this);
        log.info("【websocket】有新的連接,總數:{}",webSocketSet.size());
    }
 
    @OnClose
    public void onClose(){
        String id = this.session.getId();
        if (id != null){
            webSocketSet.remove(id);
            log.info("【websocket】連接斷開:總數:{}",webSocketSet.size());
        }
    }
 
    @OnMessage
    public void onMessage(String message){
        if (!message.equals("ping")){
            log.info("【wesocket】收到客戶端發送的消息,message={}",message);
            sendMessage(message);
        }
    }
 
    /**
     * 發送消息
     * @param message
     * @return 全部都發送一遍
     */
    public void sendMessage(String message){
        for (WebSocket webSocket : webSocketSet.values()) {
            webSocket.session.getAsyncRemote().sendText(message);
        }
        log.info("【wesocket】廣播消息,message={}", message);
 
    }
 
}

4. 添加 controller 和 客戶端

添加 controller

?
1
2
3
4
5
@GetMapping({"","index.html"})
public ModelAndView index() {
    ModelAndView view = new ModelAndView("index");
    return view;
}

添加ftl頁面

?
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
<!DOCTYPE html>
<html>
<head>
    <title>websocket</title>
</head>
<body>
<div>
    <input type="text" name="message" id="message">
    <button id="sendBtn">發送</button>
</div>
<div style="width:100px;height: 500px;" id="content">
</div>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.js"></script>
<script type="text/javascript">
    var ws = new WebSocket("ws://127.0.0.1:8080/message");
    ws.onopen = function(evt) {
        console.log("Connection open ...");
    };
 
    ws.onmessage = function(evt) {
        console.log( "Received Message: " + evt.data);
        var p = $("<p>"+evt.data+"</p>")
        $("#content").prepend(p);
        $("#message").val("");
    };
 
    ws.onclose = function(evt) {
        console.log("Connection closed.");
    };
 
    $("#sendBtn").click(function(){
        var aa = $("#message").val();
        ws.send(aa);
    })
 
</script>
</body>
</html>

5. 展示效果

Spring Boot 整合單機websocket的步驟 附github源碼

附錄

github源碼

到此這篇關于Spring Boot 整合單機websocket 附github源碼的文章就介紹到這了,更多相關Spring Boot 整合websocket內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://www.cnblogs.com/jeremylai7/p/15378748.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成人影院视频 | 国产成人精品综合在线观看 | 精品人人做人人爽久久久 | 国产一区二区视频在线播放 | 日本在线观看视频网站 | 女人把扒开给男人爽的 | chinese高中生gay男同 | 丝瓜视频在线观看污 | 草莓香蕉绿巨人丝瓜榴莲18 | 精品亚洲456在线播放 | 91精品国产高清久久久久 | 国产90后美女露脸在线观看 | 国内精品视频一区二区三区八戒 | 2019nv天堂| 3d蒂法受辱在线播放 | 爱情岛论坛自拍永久入口 | 肉色欧美久久久久久久蜜桃 | 欧美s级人做人爱c视频 | 国产精品免费看香蕉 | 色天使亚洲综合在线观看 | 国内精品免费一区二区三区 | 日本久久热 | 99re视频精品全部免费 | 97午夜| 国产在线视频福利 | 三体动漫在线观看免费完整版2022 | 婚前试爱全集免费观看 | 四虎影视在线观看永久地址 | 色伦网| 嫩草视频在线观看视频播放 | 久久99国产综合精品AV蜜桃 | 日韩精品一区二区三区中文在线 | 爽新片xxxxxxx| 免费黄色片在线观看 | 国产成人精品曰本亚洲78 | 金发美女与黑人做爰 | caoporen97免费公开视频 | 三级伦理影院 | 催奶师小说 | 舔穴吸奶 | 美女全身体光羞羞漫画 |