精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

SpringBoot 3 實戰:打造讓屏幕飛起來的實時彈幕系統

開發 架構
前端主要用 HTML + CSS + JS + SockJS + STOMP 來連接后端 WebSocket 并渲染彈幕。? HTML、CSS 與 JS 代碼邏輯基本與原示例一致,可直接復用。

在如今的視頻與直播領域,實時彈幕已經不僅是一個“酷炫的裝飾”,而是觀眾互動體驗的核心組成部分。無論是B站的番劇播放,還是各大直播平臺的賽事解說,彈幕早已成為用戶情緒的直接出口:有人激情吐槽,有人在線補充知識點,還有人花式整活帶動氣氛。 如果視頻是舞臺,那么彈幕就是現場觀眾的合唱,它讓屏幕不再孤獨。

本文將帶你使用 Spring Boot 3 + WebSocket,從零搭建一個高性能、可擴展的實時彈幕系統,前后端全流程覆蓋,并包含 消息存儲、內容過濾、歷史回放 等完整功能,讓你的視頻項目立刻具備“會說話的屏幕”。

彈幕系統概述

彈幕的定義

所謂彈幕,就是用戶在觀看視頻時發送的即時評論,這些評論會在視頻畫面上以滾動的形式(從右向左)浮動顯示。它的特點在于:

  • 即時性:觀眾的評論會幾乎同步出現在所有人的屏幕上。
  • 互動性:觀眾能即時看到他人反應,形成群體觀看氛圍。
  • 時間點關聯:彈幕通常綁定在視頻的特定播放時刻。
  • 視覺沖擊:大量彈幕同時出現時,屏幕會像被“刷屏”一樣,帶來強烈的視覺體驗。

 技術挑戰

一個成熟的彈幕系統,不僅要,還要。主要挑戰包括:

  • 高并發下的低延遲通信
  • 大量消息的傳輸與分發
  • 敏感詞過濾與格式規范
  • 彈幕的歷史存儲與回放

系統架構設計

我們實現的實時彈幕系統由以下核心模塊組成:

模塊

作用

前端播放器

播放視頻并渲染彈幕

WebSocket 服務端

負責實時消息收發

彈幕存儲層

保存歷史記錄

內容過濾組件

過濾敏感與違規內容

 協議選擇

我們需要一種低延遲、雙向通信的協議來驅動彈幕實時性:

  • WebSocket:全雙工通信,延遲極低,適合高實時性應用(本文選用)
  • SSE:僅支持服務器單向推送,適合數據廣播場景
  • 長輪詢:兼容性好但延遲高,僅作為兜底方案

后端實現(Spring Boot 3 + WebSocket)

后端目錄結構

/src
 └── main
     ├── java
     │    └── com
     │         └── icoderoad
     │              └── danmaku
     │                   ├── config
     │                   │    └── WebSocketConfig.java
     │                   ├── controller
     │                   │    └── DanmakuController.java
     │                   ├── dto
     │                   │    └── DanmakuDTO.java
     │                   ├── entity
     │                   │    └── Danmaku.java
     │                   ├── mapper
     │                   │    └── DanmakuMapper.java
     │                   └── service
     │                        └── DanmakuService.java
     └── resources
          └── application.yml

Maven 依賴

<dependencies>
    <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>
    </dependency>
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-spring-boot3-starter</artifactId>
        <version>3.5.5</version>
    </dependency>
    <dependency>
        <groupId>com.h2database</groupId>
        <artifactId>h2</artifactId>
        <scope>runtime</scope>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>
</dependencies>

WebSocket 配置

package com.icoderoad.danmaku.config;


import org.springframework.context.annotation.Configuration;
import org.springframework.messaging.simp.config.MessageBrokerRegistry;
import org.springframework.web.socket.config.annotation.*;


@Configuration
@EnableWebSocketMessageBroker
public class WebSocketConfig implements WebSocketMessageBrokerConfigurer {
    @Override
    public void configureMessageBroker(MessageBrokerRegistry config) {
        config.enableSimpleBroker("/topic"); // 客戶端訂閱路徑
        config.setApplicationDestinationPrefixes("/app"); // 客戶端發送路徑
    }


    @Override
    public void registerStompEndpoints(StompEndpointRegistry registry) {
        registry.addEndpoint("/ws-danmaku")
                .setAllowedOriginPatterns("*")
                .withSockJS(); // 兼容性支持
    }
}

實體與DTO

package com.icoderoad.danmaku.entity;


import com.baomidou.mybatisplus.annotation.*;
import lombok.Data;
import java.time.LocalDateTime;


@Data
@TableName("danmaku")
public class Danmaku {
    @TableId(type = IdType.AUTO)
    private Long id;
    private String content;
    private String color;
    private Integer fontSize;
    private Double time;
    private String videoId;
    private String userId;
    private String username;
    private LocalDateTime createdAt;
}
package com.icoderoad.danmaku.dto;


import lombok.Data;


@Data
public class DanmakuDTO {
    private String content;
    private String color = "#ffffff";
    private Integer fontSize = 24;
    private Double time;
    private String videoId;
    private String userId;
    private String username;
}
Mapper
package com.icoderoad.danmaku.mapper;


import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.icoderoad.danmaku.entity.Danmaku;
import org.apache.ibatis.annotations.*;


import java.util.List;


@Mapper
public interface DanmakuMapper extends BaseMapper<Danmaku> {
    @Select("SELECT * FROM danmaku WHERE video_id = #{videoId} ORDER BY time ASC")
    List<Danmaku> findByVideoIdOrderByTimeAsc(String videoId);


    @Select("SELECT * FROM danmaku WHERE video_id = #{videoId} AND time BETWEEN #{start} AND #{end} ORDER BY time ASC")
    List<Danmaku> findByVideoIdAndTimeBetween(String videoId, Double start, Double end);
}

服務層

package com.icoderoad.danmaku.service;


import com.icoderoad.danmaku.dto.DanmakuDTO;
import com.icoderoad.danmaku.entity.Danmaku;
import com.icoderoad.danmaku.mapper.DanmakuMapper;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.messaging.simp.SimpMessagingTemplate;
import org.springframework.stereotype.Service;


import java.time.LocalDateTime;
import java.util.List;


@Service
public class DanmakuService {
    @Autowired
    private DanmakuMapper mapper;
    @Autowired
    private SimpMessagingTemplate template;


    public Danmaku saveDanmaku(DanmakuDTO dto) {
        Danmaku d = new Danmaku();
        d.setContent(filter(dto.getContent()));
        d.setColor(dto.getColor());
        d.setFontSize(dto.getFontSize());
        d.setTime(dto.getTime());
        d.setVideoId(dto.getVideoId());
        d.setUserId(dto.getUserId());
        d.setUsername(dto.getUsername());
        d.setCreatedAt(LocalDateTime.now());


        mapper.insert(d);
        template.convertAndSend("/topic/video/" + d.getVideoId(), d);
        return d;
    }


    public List<Danmaku> listByVideo(String videoId) {
        return mapper.findByVideoIdOrderByTimeAsc(videoId);
    }


    public List<Danmaku> listByVideoAndTime(String videoId, Double start, Double end) {
        return mapper.findByVideoIdAndTimeBetween(videoId, start, end);
    }


    private String filter(String content) {
        String[] badWords = {"敏感詞1", "敏感詞2"};
        String result = content;
        for (String w : badWords) result = result.replaceAll(w, "***");
        return result;
    }
}

控制器

package com.icoderoad.danmaku.controller;


import com.icoderoad.danmaku.dto.DanmakuDTO;
import com.icoderoad.danmaku.entity.Danmaku;
import com.icoderoad.danmaku.service.DanmakuService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.ResponseEntity;
import org.springframework.messaging.handler.annotation.MessageMapping;
import org.springframework.web.bind.annotation.*;


import java.util.List;


@RestController
@RequestMapping("/api/danmaku")
public class DanmakuController {
    @Autowired
    private DanmakuService service;


    @MessageMapping("/danmaku/send")
    public Danmaku send(DanmakuDTO dto) {
        return service.saveDanmaku(dto);
    }


    @GetMapping("/video/{videoId}")
    public ResponseEntity<List<Danmaku>> list(@PathVariable String videoId) {
        return ResponseEntity.ok(service.listByVideo(videoId));
    }


    @GetMapping("/video/{videoId}/timerange")
    public ResponseEntity<List<Danmaku>> listByTime(
            @PathVariable String videoId,
            @RequestParam Double start,
            @RequestParam Double end) {
        return ResponseEntity.ok(service.listByVideoAndTime(videoId, start, end));
    }
}

前端實現

前端主要用 HTML + CSS + JS + SockJS + STOMP 來連接后端 WebSocket 并渲染彈幕。 HTML、CSS 與 JS 代碼邏輯基本與原示例一致,可直接復用。

結論

通過本文的實踐,我們構建了一個 高性能、可擴展、支持實時互動 的彈幕系統。 它不僅適用于視頻平臺,也能擴展到 在線課堂、賽事直播、虛擬演唱會 等場景。 未來我們可以進一步引入 AI 彈幕審核消息分布式存儲延遲優化算法 等,讓系統在性能體驗上更進一步。

屏幕不只是顯示畫面,它還可以承載情緒與對話。 讓我們把屏幕變成一個會回應觀眾的“現場”——這就是實時彈幕的魅力。

責任編輯:武曉燕 來源: 路條編程
相關推薦

2019-03-25 08:05:35

Elasticsear優化集群

2025-06-04 01:35:00

RocketMQ異步消息

2020-09-29 07:54:05

Express 飛起

2011-04-13 10:51:58

MATLAB

2025-03-28 03:20:00

MySQL數據庫搜索

2019-11-05 10:35:57

SpringBoot調優Java

2022-10-09 18:14:31

訂單系統分庫分表

2021-07-13 07:52:03

SQL面試COUNT(*)

2025-01-17 09:23:31

2025-06-26 02:15:00

2025-04-15 00:00:00

2024-11-27 09:46:34

2013-01-07 09:34:43

CodeLoveBAT

2011-02-25 08:39:11

QFabric數據中心Juniper

2025-09-02 01:35:00

JavaAIMIP

2025-07-30 01:22:00

2016-01-19 17:03:59

數據中心網絡華為

2024-06-12 12:28:23

2011-09-27 13:25:05

Web

2023-03-01 23:59:23

Java開發
點贊
收藏

51CTO技術棧公眾號

桃色一区二区| 国产浮力第一页| 色一区二区三区四区| 欧美一区二区三区小说| 男女私大尺度视频| av午夜在线| 粉嫩aⅴ一区二区三区四区 | 欧美日韩国产美| 成人在线视频一区二区三区| 你懂得在线网址| 狠狠色丁香久久婷婷综| 国产91成人video| 又嫩又硬又黄又爽的视频| 成人黄色av网址| 欧美日韩黄色一区二区| 久久久亚洲精品无码| 人人干在线视频| 久久久五月婷婷| 成人动漫视频在线观看完整版| 中文字幕免费高清网站| 亚洲国产日韩在线| 久久网福利资源网站| 超碰97在线资源站| 深夜福利一区| 欧美老女人在线| 激情婷婷综合网| 麻豆视频在线观看免费网站黄| 国产精品家庭影院| 人偷久久久久久久偷女厕| 亚洲精品一级片| 国产一区激情在线| 国产精品第2页| 亚洲国产成人无码av在线| 国产精品多人| 欧美国产第一页| a级片在线观看免费| 日韩在线二区| 一区二区亚洲欧洲国产日韩| 国产精品jizz| 亚洲影院天堂中文av色| 亚洲国产高清自拍| 中文字幕三级电影| 9国产精品午夜| 亚洲成人黄色网| 又色又爽又黄18网站| 精品国产鲁一鲁****| 欧美老女人第四色| 中文字幕 欧美日韩| 欧美美女福利视频| 欧美久久一二区| jizz18女人| 亚洲电影二区| 91精品国产色综合久久久蜜香臀| 婷婷免费在线观看| 亚洲伦理一区二区| 91麻豆精品国产91久久久久| 男男受被啪到高潮自述| 日韩精品成人| 精品国产区一区| 精品一区二区视频在线观看 | 亚洲成人a级网| 欧美在线一级片| 亚洲品质自拍| 综合av色偷偷网| 国产激情无码一区二区三区| 亚洲精品tv久久久久久久久久| 久久亚洲春色中文字幕| 青青草手机视频在线观看| 国内精品久久久久久久97牛牛| 欧美精品一本久久男人的天堂| 99热精品免费| 99精品久久久| 欧美女王vk| 午夜在线成人av| 国产3p露脸普通话对白| 日韩脚交footjobhd| 色综合久久久久综合99| 男女视频一区二区三区| 国产精品诱惑| 欧美一区在线视频| 韩国三级视频在线观看| 欧美一区二区三区久久| 国产亚洲精品一区二区| 99鲁鲁精品一区二区三区| 午夜久久99| **欧美日韩vr在线| 一级二级三级视频| 国产v综合v亚洲欧| 久久精品女人的天堂av| 无遮挡的视频在线观看 | 亚洲黄色一区二区三区| a级毛片免费观看在线| 亚洲国产精品久久人人爱| 欧美精品一区二区三区免费播放| 欧美一级免费| 精品粉嫩超白一线天av| 受虐m奴xxx在线观看| 午夜精品毛片| 欧美一级视频免费在线观看| 亚洲天堂自拍偷拍| 成人av在线看| 亚洲精品电影在线一区| 999精品网| 欧美视频一区二区三区在线观看| 天堂va欧美va亚洲va老司机| 久久综合欧美| 久久久久久噜噜噜久久久精品| 神马久久久久久久| 国产成人无遮挡在线视频| 日产国产精品精品a∨| 在线观看免费视频你懂的| 色视频成人在线观看免| 日本人妻一区二区三区| 日韩一区三区| 日本精品久久久久影院| 精品国产一级片| 国产精品免费av| av网站在线观看不卡| 亚洲乱码一区| 色婷婷久久一区二区| 四虎成人永久免费视频| 国产资源在线观看入口av| 日本成人中文字幕| 国产在线精品一区二区中文| 快射视频在线观看| 欧美性色黄大片手机版| 亚洲国产精品成人综合久久久| 91精品99| 国产欧美va欧美va香蕉在| 视频一区二区在线播放| 亚洲一区二区三区在线播放| 一级淫片在线观看| 日韩成人精品一区二区| 人人澡人人澡人人看欧美| 日批视频免费播放| 一区二区三区四区av| 中文字幕中文在线| 日韩免费看片| 国产精品久久久久久五月尺 | 亚洲视频在线观看免费| 在线观看国产亚洲| heyzo一本久久综合| 女人被男人躁得好爽免费视频 | 久久成人国产| 精品乱子伦一区二区三区| h片在线观看| 欧美精品一区二区三区蜜桃| 国产一级二级三级| 国产剧情一区在线| www婷婷av久久久影片| 日韩精品久久久久久久软件91| www欧美日韩| 国产精品毛片一区视频播 | 你懂的国产在线| 99re这里只有精品视频首页| 亚洲 高清 成人 动漫| 日韩高清一级| 国产精品99久久久久久www| 国产三级视频在线播放线观看| 色偷偷久久人人79超碰人人澡| 国产精品亚洲无码| 丝袜亚洲另类欧美综合| 神马欧美一区二区| 日韩护士脚交太爽了| 久久中文字幕在线| 亚洲乱色熟女一区二区三区| 亚洲资源中文字幕| 精品黑人一区二区三区观看时间| 国产精品久久久一区二区| 欧美综合激情| 国产精品美女午夜爽爽| 精品中文字幕乱| 神马午夜在线观看| 色天使色偷偷av一区二区| 五月婷婷综合激情网| 国产一区二区伦理| 成人免费性视频| 在线看成人短视频| 91九色国产视频| 国产精品xx| 国产亚洲欧美日韩美女| 精品国产无码AV| 欧美日韩一区二区精品| jizz18女人高潮| 国产成人精品网址| 各处沟厕大尺度偷拍女厕嘘嘘| 精品视频免费| 大波视频国产精品久久| 电影网一区二区| 久久中国妇女中文字幕| 深夜影院在线观看| 777奇米四色成人影色区| 日本少妇性高潮| 中文字幕av一区二区三区免费看 | 国产亚洲欧美激情| 做a视频在线观看| 国产美女一区| 黄色网zhan| 国产精品亚洲片在线播放| 亚洲综合色激情五月| 欧美电影h版| 欧美老少做受xxxx高潮| 国产毛片在线| 亚洲第一福利在线观看| 亚洲在线观看av| 欧美视频在线看| 欧美精品一区二区成人| 中文字幕不卡的av| 久久久久久久久免费看无码| 国产一区二区三区观看| 男女啪啪网站视频| 国产欧美精品| 伊人网在线免费| 日韩欧美视频在线播放| 麻豆亚洲一区| 超碰97久久| 亚洲a在线观看| 国产精品原创视频| 日韩av片电影专区| mm视频在线视频| 久久福利网址导航| chinese偷拍一区二区三区| 亚洲精品久久久久久久久久久 | 播放一区二区| 国模吧一区二区| 怡红院红怡院欧美aⅴ怡春院| 在线成人免费网站| 久草在线青青草| 日韩成人在线电影网| 亚洲免费一级片| 日韩欧美aaaaaa| av网站在线免费看| 337p亚洲精品色噜噜噜| 中文av免费观看| 91成人在线观看喷潮| 成人毛片18女人毛片| 亚洲一区二区三区在线| 久久亚洲精品大全| 一区二区三区欧美日韩| 粉嫩av性色av蜜臀av网站| 国产精品白丝在线| 手机看片国产日韩| 中文字幕久久午夜不卡| 无码少妇一区二区| 久久久久久一级片| 尤物视频最新网址| 国产亚洲一区字幕| 中文字幕在线观看免费高清 | 日本一区二区三区在线视频| 在线日本制服中文欧美| 欧美高清性xxxxhdvideosex| 日韩mv欧美mv国产网站| 久久久久久久久一区二区| 国产精品久久久网站| 国产精品区一区二区三含羞草| 91亚洲精品视频在线观看| 国产欧美丝袜| 色婷婷综合久久久久久| 日本婷婷久久久久久久久一区二区| 色婷婷狠狠五月综合天色拍| 免费h精品视频在线播放| 亚洲人成精品久久久| 日本一区二区在线| 婷婷综合伊人| 成年人看的毛片| 久久中文在线| 性生活免费在线观看| 国产一区二区导航在线播放| 香蕉视频在线观看黄| 成人免费高清在线观看| 蜜桃av免费看| 国产精品久久综合| 欧美片一区二区| 日韩欧美国产骚| 一二区在线观看| 精品粉嫩超白一线天av| 免费在线视频一级不卡| 日韩资源在线观看| a级片免费在线观看| 国产成人精品一区二区在线| 中文字幕日韩亚洲| 国产精品久久久一区二区三区| 激情av综合| 日韩av在线电影观看| 亚洲人metart人体| 日本日本19xxxⅹhd乱影响| 日本在线不卡一区| 亚洲av无码久久精品色欲| www.欧美日韩国产在线| 国产探花视频在线播放| 亚洲一区成人在线| 国产精品午夜一区二区| 日韩精品资源二区在线| 国产黄色片在线观看| 欧美贵妇videos办公室| 电影一区电影二区| 极品尤物一区二区三区| 91影院成人| 欧美日韩国产精品激情在线播放| 麻豆国产精品官网| 激情综合丁香五月| 自拍视频在线观看一区二区| 久久中文字幕免费| 欧美一级理论片| 国产青青草在线| 亚洲 日韩 国产第一| 国产视频网站一区二区三区| 欧美成人综合一区| 黄色成人在线网站| 久久国产精品国产精品| 91色porny蝌蚪| a级片在线观看免费| 欧美日韩精品欧美日韩精品一| 日韩永久免费视频| 久久久精品欧美| 91国内外精品自在线播放| 国产精品日韩欧美一区二区| 亚洲第一偷拍| 三上悠亚在线一区二区| 久久这里只精品最新地址| 久草免费在线观看视频| 欧美另类一区二区三区| 成人三级黄色免费网站| 欧美一级在线亚洲天堂| 国产精品久久久久av蜜臀| 50度灰在线观看| 久久99精品国产麻豆婷婷| 无码人妻丰满熟妇啪啪欧美| 欧美性极品xxxx做受| 天堂中文在线资源| 欧美精品久久久久| 五月亚洲婷婷| 米仓穗香在线观看| 国产一区视频在线看| 黄色录像二级片| av福利精品| 日日摸夜夜添一区| 日韩毛片一区| 日韩成人在线资源| 日韩国产欧美三级| 国产高清一区二区三区四区| 欧美性猛交xxxx久久久| 涩涩视频在线观看免费| 91精品国产一区| 台湾亚洲精品一区二区tv| 2022亚洲天堂| 91丨九色porny丨蝌蚪| 国产成人在线播放视频| 日韩精品久久久久久福利| sm久久捆绑调教精品一区| 国产日韩精品久久| 国产精品美女| 亚洲欧美视频在线播放| 黑人巨大精品欧美一区二区免费 | 成人av免费网站| 国产污片在线观看| 亚洲精品短视频| 成人美女视频| 亚洲精品成人a8198a| 精品一区在线看| 久草视频免费在线| 日韩精品视频免费专区在线播放| 美女av在线免费看| 麻豆久久久9性大片| 日韩精品电影在线| sm捆绑调教视频| 日韩午夜小视频| 九色porny丨国产首页在线| 欧美精品与人动性物交免费看| 日韩精品久久久久久| 日本黄色动态图| 日本道在线观看一区二区| 欧美精品日韩少妇| 岛国视频一区免费观看| 久久蜜桃精品| 精品在线观看一区| 日韩欧美在线影院| 粉嫩一区二区| 一区二区三区偷拍| 成人夜色视频网站在线观看| 亚洲高清毛片一区二区| 在线视频日本亚洲性| 麻豆国产一区| 男人操女人逼免费视频| 国产精品电影院| 人妻少妇精品无码专区| 国产精品三级网站| 欧美亚洲不卡| 亚洲av成人无码久久精品| 日韩一区二区三区av| 一个人看的www视频在线免费观看| 午夜精品视频在线观看一区二区| 国产乱码精品一区二区三区五月婷| 国产精品第72页| 色婷婷综合久久久久中文字幕1| 8848成人影院| 日本黄色的视频| 欧美日韩国产色视频| 成人在线网址| 欧美专区一二三|