当前位置: 首页 > wzjs >正文

html5网站价格电脑培训网上免费课程

html5网站价格,电脑培训网上免费课程,做网络销售保温材料用什么网站好,百度旗下所有app列表用 Spring Boot Redis 实现哔哩哔哩弹幕系统 支持:历史弹幕 实时弹幕 敏感词过滤 限频 持久化 🧩 项目功能总览 功能模块技术实现🎞 历史弹幕Redis List 存储,按时间排序展示📡 实时弹幕WebSocket 双向通信 广…

用 Spring Boot + Redis 实现哔哩哔哩弹幕系统

支持:历史弹幕 + 实时弹幕 + 敏感词过滤 + 限频 + 持久化


🧩 项目功能总览

功能模块技术实现
🎞 历史弹幕Redis List 存储,按时间排序展示
📡 实时弹幕WebSocket 双向通信 + 广播
🚫 敏感词过滤Redis Set 管理敏感词,系统提醒用户
🚦 弹幕防刷限频Redis 键限速,每人 2 秒 1 条
📦 持久化存储Redis 弹幕每 30 秒批量写入 MySQL
🧑‍💼 管理接口敏感词添加/删除/查看 REST 接口

🧱 技术栈

层级技术说明
后端Spring Boot主体开发框架
通信WebSocket实时弹幕传输
缓存Redis弹幕缓存、限频控制
数据库MySQL弹幕历史存储
前端HTML + JS视频播放 + 弹幕显示

🗃️ 弹幕数据模型(MySQL)

CREATE TABLE danmu (id BIGINT AUTO_INCREMENT PRIMARY KEY,video_id BIGINT NOT NULL,user_id VARCHAR(50),text VARCHAR(255),time_in_video DOUBLE,send_time DATETIME
);

☁️ Redis 数据结构设计

Key类型示例值
danmu:video:{videoId}List弹幕 JSON,按时间顺序
filter:wordsSet管理敏感词
limit:user:{userId}String限制用户发送频率

☁️ Redis 存弹幕(实时 + 历史)

  • 弹幕按 timeInVideo 入 Redis List
  • 前端加载 Redis 弹幕,根据视频播放进度展示
  • 每隔 30 秒自动将 Redis 弹幕落库并清除缓存

🔐 敏感词过滤系统(服务 + 接口)

🔧 Redis Filter Service

@Service
public class DanmuFilterService {@Autowired RedisTemplate<String, String> redis;public boolean containsForbidden(String text) {Set<String> words = redis.opsForSet().members("filter:words");return words != null && words.stream().anyMatch(text::contains);}
}

🔧 管理接口

@RestController
@RequestMapping("/api/filters")
public class FilterController {@Autowired RedisTemplate<String, String> redis;@PostMapping("/add")public String add(@RequestParam String word) {redis.opsForSet().add("filter:words", word);return "添加成功";}@PostMapping("/remove")public String remove(@RequestParam String word) {redis.opsForSet().remove("filter:words", word);return "删除成功";}@GetMapping("/list")public Set<String> list() {return redis.opsForSet().members("filter:words");}
}

🚦 弹幕限频控制

👮 Redis 限流器

@Service
public class DanmuRateLimitService {@Autowired RedisTemplate<String, String> redis;public boolean isTooFast(String userId) {String key = "limit:user:" + userId;if (redis.hasKey(key)) return true;redis.opsForValue().set(key, "1", Duration.ofSeconds(2));return false;}
}

🔄 定时将弹幕持久化到 MySQL

@Component
public class DanmuBackupTask {@Autowired RedisTemplate<String, String> redis;@Autowired DanmuRepository danmuRepo;Gson gson = new Gson();@Scheduled(fixedRate = 30000) // 每 30 秒public void flushToDb() {Set<String> keys = redis.keys("danmu:video:*");if (keys == null) return;for (String key : keys) {List<String> list = redis.opsForList().range(key, 0, -1);if (list == null || list.isEmpty()) continue;List<Danmu> danmus = list.stream().map(j -> gson.fromJson(j, Danmu.class)).toList();danmuRepo.saveAll(danmus);redis.delete(key); // 清空 Redis}}
}

📡 WebSocket 处理器(敏感词 + 限频 + 广播)

@ServerEndpoint("/ws/danmu/{videoId}/{userId}")
@Component
public class DanmuWebSocket {private static final Map<String, Session> sessions = new ConcurrentHashMap<>();private static DanmuFilterService filterService;private static DanmuRateLimitService rateLimitService;private static RedisTemplate<String, String> redis;@Autowiredpublic void setDeps(DanmuFilterService f, DanmuRateLimitService r, RedisTemplate<String, String> rt) {filterService = f;rateLimitService = r;redis = rt;}@OnOpenpublic void onOpen(Session session) {sessions.put(session.getId(), session);}@OnMessagepublic void onMessage(String msgJson, Session session,@PathParam("videoId") String videoId,@PathParam("userId") String userId) {Danmu danmu = new Gson().fromJson(msgJson, Danmu.class);danmu.setUserId(userId);danmu.setSendTime(LocalDateTime.now());// 限频if (rateLimitService.isTooFast(userId)) {sendTo(session, "[系统通知] 请勿频繁发送弹幕!");return;}// 敏感词if (filterService.containsForbidden(danmu.getText())) {sendTo(session, "[系统通知] 弹幕含违禁词,已屏蔽!");return;}// 存 Redisredis.opsForList().rightPush("danmu:video:" + videoId, new Gson().toJson(danmu));// 广播sessions.values().forEach(s -> sendTo(s, new Gson().toJson(danmu)));}private void sendTo(Session session, String msg) {try { session.getBasicRemote().sendText(msg); } catch (Exception e) {}}@OnClosepublic void onClose(Session session) {sessions.remove(session.getId());}
}

💻 前端弹幕逻辑(伪代码)

// 加载历史弹幕
fetch("/api/danmu/history?videoId=123").then(res => res.json()).then(data => {danmus = data.sort((a, b) => a.time - b.time);});setInterval(() => {const currentTime = video.currentTime;while (danmus.length && danmus[0].time <= currentTime) {showDanmu(danmus.shift().text);}
}, 200);// 连接 WebSocket
const ws = new WebSocket("ws://localhost:8080/ws/danmu/123/userA");
ws.onmessage = e => showDanmu(JSON.parse(e.data).text);// 发送弹幕
function sendDanmu(text) {ws.send(JSON.stringify({ text, time: video.currentTime }));
}

✅ 最终效果

功能效果
实时弹幕多用户同步,实时显示
历史弹幕视频播放自动同步
敏感词拦截系统通知+拦截广播
防刷控制每 2 秒最多 1 条
持久化保障弹幕定时入库


🧪 当前系统存在的缺点分析

分类问题描述影响改进建议
🏗 架构WebSocket 逻辑中 Redis 和 Spring Bean 注入依赖手动静态赋值不规范,难维护,容易出错使用 @Component + @ServerEndpointExporter 或 Spring WebSocket(STOMP)替代
💾 数据存储Redis 弹幕写入后一次性 flush 到 MySQL,每次清空缓存如果任务挂掉,数据可能丢失采用 MQ(如 Kafka)异步写库,或采用 AOF 持久化增强安全性
🧍‍♂️ 用户控制弹幕限频基于 Redis 键,粒度较粗(用户级 2 秒)不能支持每用户每视频限频、动态限速改为 Lua 脚本实现限流(滑动窗口或令牌桶)更精准
🔎 敏感词检测整体为“包含”检测,容易误伤、无法处理变形词用户体验下降 + 容易绕过支持正则、Trie 树、拼音转写等模糊检测方案
📋 管理后台敏感词接口无权限保护,任意人可添加/删除高危漏洞使用 Spring Security + 登录鉴权系统
📈 弹幕密度当前只支持“每秒多条弹幕”的简单展示方式弹幕重叠、遮挡,影响观看加入轨道(轨迹)管理:每条弹幕分配不重复轨道并添加动画队列
📺 前端展示弹幕展示样式较简单,没有封装动画、颜色、字体大小不够炫酷,体验不如 B 站使用 canvas 或独立 JS 弹幕引擎如 danmaku.js
📶 多节点支持当前广播使用内存 Map 保存所有 Session无法扩展多实例部署引入消息中间件(如 Redis Pub/Sub、Kafka)实现弹幕广播中转
💬 消息格式弹幕是纯文本,缺乏弹幕类型(滚动/顶端/底端)、颜色等字段无法实现个性化弹幕样式扩展弹幕数据结构支持样式字段:如 { text, type, color, fontSize }

✅ 总结建议

优化方向推荐技术
高可用架构Spring WebSocket + Redis Pub/Sub + Kafka
数据安全Redis AOF + MQ 异步写库
用户限频Redis Lua 限流脚本(滑动窗口算法)
敏感词检测DFA + 正则匹配 + 后台管理审查
前端动画使用弹幕引擎库,如 danmaku.js / canvas 实现
安全控制Spring Security + RBAC 管理员角色

http://www.dtcms.com/wzjs/78709.html

相关文章:

  • 响应式网站是个坑福州百度网站快速优化
  • 中国建设银行网站功能模块seo优化步骤
  • 网站建设长沙百度账号出售平台
  • 写网站建设需求如何在百度上开店铺
  • 我做网站推广网络营销推广策划书
  • 做企业官网需要java吗seow是什么意思
  • 表白二维码制作网站最新热搜榜
  • python做网站的好处自己怎么优化关键词
  • 网站推广其他方案内容淄博网站营销与推广
  • 城乡建设网站报建需要什么中文域名的网站
  • 西安哪里找做网站公司免费crm系统手机版
  • 怎样做一个企业的网站建站推广普通话手抄报图片大全
  • 网站建设最新新闻微信推广软件
  • liferay 做网站十大看免费行情的软件下载
  • 做垂直网站营销软文代写
  • 徐州人才网汕头seo快速排名
  • 模板网站与定制网站的价格2021年年度关键词排名
  • 做营销型网站价格南宁网站制作
  • wordpress存档:合肥seo推广排名
  • 网站做扫一扫百度搜索引擎下载免费
  • 网站建设服务费如何做会计分录网络营销与直播电商专业学什么
  • 建设银行ETC的网站是哪个如何联系百度人工客服电话
  • 鞍山做网站团队百度网站建设
  • 怎样做娱乐网站网站设计流程
  • 怎么做网站海报中国十大电商公司排名
  • 企业建站费用情况网络市场营销
  • 项目网站建设应入哪个科目长沙做引流推广的公司
  • 网站抓取QQ获取系统软文投稿平台有哪些
  • 新乡市做网站烟台百度推广公司
  • 中企动力做网站的优势朋友圈产品推广文案