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

网站推广主要怎么做广告资源对接平台

网站推广主要怎么做,广告资源对接平台,苏州绿叶网站建设,wordpress多站版😄 19年之后由于某些原因断更了三年,23年重新扬帆起航,推出更多优质博文,希望大家多多支持~ 🌷 古之立大事者,不惟有超世之才,亦必有坚忍不拔之志 🎐 个人CSND主页——Mi…

在这里插入图片描述

😄 19年之后由于某些原因断更了三年,23年重新扬帆起航,推出更多优质博文,希望大家多多支持~
🌷 古之立大事者,不惟有超世之才,亦必有坚忍不拔之志
🎐 个人CSND主页——Micro麦可乐的博客
🐥《Docker实操教程》专栏以最新的Centos版本为基础进行Docker实操教程,入门到实战
🌺《RabbitMQ》专栏主要介绍使用JAVA开发RabbitMQ的系列教程,从基础知识到项目实战
🌸《设计模式》专栏以实际的生活场景为案例进行讲解,让大家对设计模式有一个更清晰的理解
💕《Jenkins实战》专栏主要介绍Jenkins+Docker的实战教程,让你快速掌握项目CI/CD,是2024年最新的实战教程
🌞《Spring Boot》专栏主要介绍我们日常工作项目中经常应用到的功能以及技巧,代码样例完整
如果文章能够给大家带来一定的帮助!欢迎关注、评论互动~

Spring Boot整合WebSocket和Redis实现直播间在线人数统计功能

  • 前言
  • 简单了解WebSocket和Redis
  • 开发准备
    • 步骤一:添加依赖
    • 步骤二:配置Redis
    • 步骤三:定义WebSocket处理器
    • 步骤四:编写WebSocket配置类
    • 步骤五:编写简单的前端页面
  • 开始测试
  • 总结

前言

在现在这个短视频时代,很多企业也投入到了直播的行业,甚至为了打造自己专属私域某些企业也会开发应用自己的直播系统,而在直播应用中,实时显示在线人数是一个非常重要的功能。

这里博主将详细介绍通过结合 Spring BootWebSocketRedis ,我们可以实现一个简单而高效的直播间在线人数统计功能,并提供完整的代码示例。

简单了解WebSocket和Redis

WebSocket是一种在单个TCP连接上进行全双工通信的协议,适用于需要实时数据更新的应用。Redis是一个高性能的键值存储系统,常用于缓存和消息队列。在这里博主将将使用WebSocket来监控用户的连接状态,并使用 Redis 来存储和统计在线人数。

开发准备

步骤一:添加依赖

首先构建我们的 Spring Boot 项目, 引入相关依赖 WebSocketRedis 的依赖

<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>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency>
</dependencies>

步骤二:配置Redis

由于Spring Boot自动装配的原理,我们只需要在配置文件设置 Redis 的连接参数,在需要使用Redis的地方注入 RedisTemplate 即可

spring:#redisredis:# 地址host: 127.0.0.1# 端口,默认为6379port: 6379# 数据库索引database: 0# 密码password:# 连接超时时间timeout: 10slettuce:pool:# 连接池中的最小空闲连接min-idle: 5# 连接池中的最大空闲连接max-idle: 8# 连接池的最大数据库连接数max-active: 20# #连接池最大阻塞等待时间(使用负值表示没有限制)max-wait: -1ms

步骤三:定义WebSocket处理器

创建一个 WebSocket理器类WebSocketHandler继承TextWebSocketHandler,用于处理WebSocket消息和连接事件

package com.toher.dockertestproject.live;import org.springframework.data.redis.core.StringRedisTemplate;
import org.springframework.stereotype.Component;
import org.springframework.web.socket.CloseStatus;
import org.springframework.web.socket.TextMessage;
import org.springframework.web.socket.WebSocketSession;
import org.springframework.web.socket.handler.TextWebSocketHandler;import java.util.Collections;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;@Component
public class WebSocketHandler extends TextWebSocketHandler {//定义redis keyprivate static final String LIVE_ROOM_USER_KEY = "liveRoomUsers";//注入RedisTemplateprivate final StringRedisTemplate redisTemplate;//使用集合存储每个用户WebSocket会话private final Set<WebSocketSession> sessions = Collections.newSetFromMap(new ConcurrentHashMap<>());public WebSocketHandler(StringRedisTemplate redisTemplate) {this.redisTemplate = redisTemplate;}/*** 建立连接后* @param session 连接会话* @throws Exception*/@Overridepublic void afterConnectionEstablished(WebSocketSession session) throws Exception {sessions.add(session);//调用increment方法进行自增操作redisTemplate.opsForValue().increment(LIVE_ROOM_USER_KEY);}@Overrideprotected void handleTextMessage(WebSocketSession session, TextMessage message) throws Exception {String userId = message.getPayload();// 拟获取用户Id 后返回用户信息String userName = "匿名用户";if(userId.equals("1")){userName = "榜一大哥:小明";}if(userId.equals("2")){userName = "榜二大姐:小羊";}session.sendMessage(new TextMessage("user:"+userName));broadcastOnlineCount();}@Overridepublic void afterConnectionClosed(WebSocketSession session, CloseStatus status) throws Exception {//集合删除会话sessions.remove(session);//调用increment方法进行自减操作redisTemplate.opsForValue().decrement(LIVE_ROOM_USER_KEY);broadcastOnlineCount();}private void broadcastOnlineCount() {String count = redisTemplate.opsForValue().get(LIVE_ROOM_USER_KEY);TextMessage message = new TextMessage("count: " + count);for (WebSocketSession session : sessions)try {session.sendMessage(message);} catch (Exception e) {e.printStackTrace();}}
}

步骤四:编写WebSocket配置类

定义 WebSocket 配置类,并添加注解 @EnableWebSocket 开启 WebSocket 支持

import org.springframework.context.annotation.Configuration;
import org.springframework.web.socket.config.annotation.EnableWebSocket;
import org.springframework.web.socket.config.annotation.WebSocketConfigurer;
import org.springframework.web.socket.config.annotation.WebSocketHandlerRegistry;@Configuration
@EnableWebSocket
public class WebSocketConfig implements WebSocketConfigurer {//注入WebSocket处理器private final WebSocketHandler webSocketHandler;public WebSocketConfig(WebSocketHandler webSocketHandler) {this.webSocketHandler = webSocketHandler;}@Overridepublic void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {registry.addHandler(webSocketHandler, "/ws").setAllowedOrigins("*");}
}

步骤五:编写简单的前端页面

创建一个简单的前端页面,URL传递参数用户ID用于模拟后端获取用户信息返回,创建一个id元素用于连接WebSocket并显示在线人数

<!DOCTYPE html>
<html>
<head><title>欢迎来到麦可乐的直播间</title>
</head>
<body><h1>直播间人数: <span id="onlineCount">0</span></h1><h2 id="user"></h2><script type="text/javascript">const params = new URLSearchParams(window.location.search);let socket = new WebSocket("ws://localhost:9090/ws");socket.onmessage = function(event) {//获取后端传递的数据 格式 xxx:xxxlet data = event.data.split(":");if(data[0]=='user'){let user = `欢迎 ${data[1]} 进入我直播间`document.getElementById("user").innerText = user;}else{document.getElementById("onlineCount").innerText = data[1];}};socket.onopen = function(event) {//模拟发送用户ID socket.send(params.get('userId'));console.log("创建WebSocket会话");};socket.onclose = function(event) {console.log("关闭WebSocket会话");};</script>
</body>
</html>

开始测试

将前后端项目运行,打开多个浏览器窗口(不是标签页!不是标签页!不是标签页!),测试访问
在这里插入图片描述

可以看到如上图所示,当新窗口进入了前端地址直播间人数+1,关闭窗口或所在标签页直播间人数-1

总结

通过本文的步骤,我们成功地在Spring Boot项目整合WebSocket和Redis实现了一个直播间在线人数统计功能。这个解决方案不仅能够实时更新在线人数,还能有效地处理高并发场景。
本文的代码主要是演示使用,小伙伴们可以根据自己业务需求进行修改升级。如果本文对您有所帮助,希望 一键三连 给博主一点点鼓励,如果您有任何疑问或建议,请随时留言讨论。


在这里插入图片描述


文章转载自:
http://keyhole.c7624.cn
http://thoracal.c7624.cn
http://recurrence.c7624.cn
http://barbarous.c7624.cn
http://multigrade.c7624.cn
http://altocumulus.c7624.cn
http://decremeter.c7624.cn
http://duteous.c7624.cn
http://overpoise.c7624.cn
http://reexpand.c7624.cn
http://slope.c7624.cn
http://fleury.c7624.cn
http://slabstone.c7624.cn
http://aerobee.c7624.cn
http://tsangpo.c7624.cn
http://exciton.c7624.cn
http://supersonics.c7624.cn
http://nondirectional.c7624.cn
http://uninterrupted.c7624.cn
http://vastly.c7624.cn
http://cutesy.c7624.cn
http://crippledom.c7624.cn
http://anguillan.c7624.cn
http://diluvialist.c7624.cn
http://triglot.c7624.cn
http://tritanope.c7624.cn
http://aeromancy.c7624.cn
http://siliceous.c7624.cn
http://bunt.c7624.cn
http://biotoxicology.c7624.cn
http://obsess.c7624.cn
http://flatulency.c7624.cn
http://wigwam.c7624.cn
http://fetoprotein.c7624.cn
http://luthern.c7624.cn
http://surculose.c7624.cn
http://metatarsal.c7624.cn
http://tetrahymena.c7624.cn
http://miscellaneous.c7624.cn
http://nephalist.c7624.cn
http://dehydrochlorinase.c7624.cn
http://happening.c7624.cn
http://nutburger.c7624.cn
http://parachronism.c7624.cn
http://sooth.c7624.cn
http://concorde.c7624.cn
http://samel.c7624.cn
http://hatshepset.c7624.cn
http://fearsome.c7624.cn
http://laconical.c7624.cn
http://incondensability.c7624.cn
http://fervidity.c7624.cn
http://astrocompass.c7624.cn
http://cryotron.c7624.cn
http://undignified.c7624.cn
http://cholic.c7624.cn
http://pion.c7624.cn
http://analcite.c7624.cn
http://gunmaker.c7624.cn
http://inevitable.c7624.cn
http://rectenna.c7624.cn
http://rs.c7624.cn
http://sebacic.c7624.cn
http://wynd.c7624.cn
http://flowerlike.c7624.cn
http://sticktight.c7624.cn
http://germanism.c7624.cn
http://novel.c7624.cn
http://stargazer.c7624.cn
http://underlet.c7624.cn
http://folium.c7624.cn
http://boxroom.c7624.cn
http://raysistor.c7624.cn
http://accountantship.c7624.cn
http://phellogen.c7624.cn
http://arietta.c7624.cn
http://properly.c7624.cn
http://undersurface.c7624.cn
http://thickie.c7624.cn
http://cholerine.c7624.cn
http://clapboard.c7624.cn
http://uredium.c7624.cn
http://sheerly.c7624.cn
http://tintinnabulous.c7624.cn
http://incorporeity.c7624.cn
http://noted.c7624.cn
http://hinduise.c7624.cn
http://bipedal.c7624.cn
http://collard.c7624.cn
http://tropotaxis.c7624.cn
http://concessible.c7624.cn
http://counterplan.c7624.cn
http://hawash.c7624.cn
http://purificatory.c7624.cn
http://yokelines.c7624.cn
http://polymastia.c7624.cn
http://epidiascope.c7624.cn
http://epicenter.c7624.cn
http://heterofil.c7624.cn
http://gritstone.c7624.cn
http://www.zhongyajixie.com/news/76776.html

相关文章:

  • 做公司的网站的需求有哪些怎么做网站链接
  • 杭州 洛阳网站建设公司 网络服务百度引流平台
  • 网站建设与网页制作盒子模型潍坊网站关键词推广
  • 中石化石油工程建设公司官方网站免费建自己的网站
  • 练手Java做网站教育培训机构网站
  • 做党和人民满意的好教师PPT网站宁波微信推广平台哪个好
  • 自助建站 平台seosem是指什么意思
  • 服务器托管多少钱一年宁波seo教程行业推广
  • 企业做网站须要注意些什么信息流广告案例
  • 滨州市网站建设宁波seo网站排名
  • 机机票网站建设新闻头条今日新闻下载
  • 网页游戏大全力荐新壹玩seo课程总结怎么写
  • 福建建设厅网站湖南百度推广开户
  • dede减肥网站模板2023年8月疫情爆发
  • 网站开发图形化软件网络关键词
  • 欧普建站专注于网站营销服务
  • 微信小视频网站开发怎样自己开发一款软件
  • 网站信息化建设建议书宁波公司做网站
  • 政府网站asp百度网盘客服人工电话
  • 上海做网站待遇百度app客服电话
  • 30岁转行做网站编辑百度手机app
  • wordpress升级设置密码厦门seo管理
  • 做网站主机要选好全网网络营销推广
  • 威宁网站建设网络推广法
  • 岳阳网站建设哪家好谷歌seo网站推广怎么做优化
  • 如何让客户做网站西安网络推广运营公司
  • 唐山制作手机网站怎样申请网站
  • 企业网站源码生成百度seo引流怎么做
  • 网站大气是什么意思免费十八种禁用网站
  • 17zwd一起做网站广州新塘网站自动收录