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

科技通信网站模板下载wordpress建小程序

科技通信网站模板下载,wordpress建小程序,网站接入服务提供商,海南网页更多SpringBoot3内容请关注我的专栏#xff1a;《SpringBoot3》 期待您的点赞#x1f44d;收藏⭐评论✍ 重学SpringBoot3-集成Redis#xff08;十二#xff09;之点赞功能实现 1. 点赞功能的场景分析2. 项目环境配置2.1. 依赖引入2.2. Redis 配置 3. 点赞功能的实现3.1. 点… 更多SpringBoot3内容请关注我的专栏《SpringBoot3》 期待您的点赞收藏⭐评论✍ 重学SpringBoot3-集成Redis十二之点赞功能实现 1. 点赞功能的场景分析2. 项目环境配置2.1. 依赖引入2.2. Redis 配置 3. 点赞功能的实现3.1. 点赞服务层3.2. 点赞控制器3.3. 演示点赞操作获取点赞数检查用户是否点赞取消点赞 4. 点赞功能的详细解释4.1. 用户点赞和取消点赞4.2. 统计点赞数4.3. 判断用户是否点赞 5. Redis Set 数据结构的优势6. 总结 在现代的应用中点赞功能是一个非常常见的需求尤其在社交媒体、博客等平台上。Redis 作为一个高性能的键值存储系统由于其读写速度快、支持丰富的数据结构因此非常适合用来实现实时的点赞功能。本文将介绍如何结合 Spring Boot 3 和 Redis 来实现一个高效的点赞功能。 1. 点赞功能的场景分析 点赞功能通常涉及以下场景 用户点赞或取消点赞某个用户对某篇文章或某条评论进行点赞或取消操作。统计点赞数量实时显示某个对象如文章、视频、评论的总点赞数。用户点赞状态查询判断某个用户是否对某个对象点赞过。 Redis 通过Set 数据结构可以很好地解决这些问题。Redis 的 Set 不允许重复元素且支持快速添加、删除、判断成员是否存在等操作。 2. 项目环境配置 2.1. 依赖引入 首先在 pom.xml 中引入 Spring Boot 3 和 Redis 的相关依赖具体参考重学SpringBoot3-集成Redis一之基本使用 dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-data-redis/artifactId /dependency2.2. Redis 配置 在 application.yml 中配置 Redis 连接 spring:data:redis:host: localhostport: 6379 # Redis 端口password: redis123456 # 如果有密码可以在这里配置lettuce:pool:max-active: 100 # 最大并发连接数max-idle: 50 # 最大空闲连接数min-idle: 10 # 最小空闲连接数3. 点赞功能的实现 在实现点赞功能时通常会用 Redis 的 Set 数据结构来存储每个对象如文章、视频的点赞用户列表。每次点赞操作就是往这个 Set 中添加用户 ID取消点赞则是从 Set 中移除用户 ID。 3.1. 点赞服务层 package com.coderjia.boot310redis.service;import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis.core.StringRedisTemplate; import org.springframework.stereotype.Service;/*** author CoderJia* create 2024/10/10 下午 09:45* Description**/ Service public class LikeService {Autowiredprivate StringRedisTemplate redisTemplate;// Redis Key 前缀private static final String LIKE_KEY_PREFIX like:; // 用户点赞public void likePost(String postId, String userId) {String redisKey LIKE_KEY_PREFIX postId;redisTemplate.opsForSet().add(redisKey, userId);}// 用户取消点赞public void unlikePost(String postId, String userId) {String redisKey LIKE_KEY_PREFIX postId;redisTemplate.opsForSet().remove(redisKey, userId);}// 查询某个帖子点赞数public Long getLikeCount(String postId) {String redisKey LIKE_KEY_PREFIX postId;return redisTemplate.opsForSet().size(redisKey);}// 判断用户是否点赞public boolean hasLiked(String postId, String userId) {String redisKey LIKE_KEY_PREFIX postId;return Boolean.TRUE.equals(redisTemplate.opsForSet().isMember(redisKey, userId));} } 3.2. 点赞控制器 package com.coderjia.boot310redis.demos.web;import com.coderjia.boot310redis.service.LikeService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.RestController;/*** author CoderJia* create 2024/10/10 下午 09:46* Description**/ RestController RequestMapping(/like) public class LikeController {Autowiredprivate LikeService likeService;// 点赞操作PostMapping(/like)public String like(RequestParam String postId, RequestParam String userId) {likeService.likePost(postId, userId);return Liked post: postId by user: userId;}// 取消点赞PostMapping(/unlike)public String unlike(RequestParam String postId, RequestParam String userId) {likeService.unlikePost(postId, userId);return Unliked post: postId by user: userId;}// 获取点赞数GetMapping(/count)public Long getLikeCount(RequestParam String postId) {return likeService.getLikeCount(postId);}// 检查用户是否点赞GetMapping(/status)public boolean hasLiked(RequestParam String postId, RequestParam String userId) {return likeService.hasLiked(postId, userId);} }3.3. 演示 点赞操作 curl -X POST http://localhost:8080/like/like?postIdp101userId1获取点赞数 curl http://localhost:8080/like/count?postIdp101检查用户是否点赞 curl http://localhost:8080/like/status?postIdp101userId1取消点赞 curl -X POST http://localhost:8080/like/unlike?postIdp101userId14. 点赞功能的详细解释 4.1. 用户点赞和取消点赞 每当用户点赞时我们将用户 ID 存入 Redis 的 Set 中。由于 Redis 的 Set 不允许重复元素用户多次点赞同一篇文章也只会被记录一次。 redisTemplate.opsForSet().add(redisKey, userId);取消点赞则是将用户 ID 从 Set 中移除 redisTemplate.opsForSet().remove(redisKey, userId);4.2. 统计点赞数 统计点赞数非常简单直接调用 Redis 的 size() 方法即可 redisTemplate.opsForSet().size(redisKey);这比使用传统数据库查询要快得多尤其在大量用户点赞的情况下Redis 能保持高性能。 4.3. 判断用户是否点赞 可以通过 Redis 的 isMember() 方法来判断某个用户是否已经对某篇文章点赞 redisTemplate.opsForSet().isMember(redisKey, userId);这一点对前端显示用户是否已点赞的状态非常重要用户体验更好。 5. Redis Set 数据结构的优势 Redis 的 Set 数据结构非常适合用来存储点赞功能的用户列表原因有以下几点 唯一性Redis Set 不允许重复元素确保用户对同一篇文章只能点赞一次。高性能Redis 是内存级存储读写速度极快适合大规模的点赞操作。丰富的操作Set 提供了丰富的操作如添加成员、删除成员、计算数量、检查成员是否存在等这些操作都是 O(1) 复杂度性能非常高。 6. 总结 通过结合 Spring Boot 3 与 Redis我们可以轻松实现高效的点赞功能并利用 Redis 的 Set 数据结构实现去重、快速统计等操作。相比于传统的数据库操作使用 Redis 实现的点赞功能性能更高、扩展性更好尤其适合用户量大、点赞操作频繁的应用场景。 持久化到数据库 仅使用 Redis适用于对数据一致性要求不高的场景比如短期有效的点赞数据或者系统对少量点赞数据丢失不敏感。 Redis MySQL方案适用于对数据一致性要求高的场景比如电商、社交平台中点赞数据不能丢失且需要长期保存。通常采用异步持久化具体流程可以是 用户点赞时首先将数据写入 Redis。通过定时任务如每隔几分钟或消息队列将 Redis 中的点赞数据同步到数据库。在定时任务或队列消费过程中可以批量将点赞数据写入数据库降低数据库的写入压力。
http://www.w-s-a.com/news/888594/

相关文章:

  • 地方门户网站制作一级做c爱片的网站
  • 自己上传图片做动漫图网站北京福田汽车
  • 一级a做爰片免费网站录像ps做网站图片水印
  • 网页广告投放成都优化推广公司
  • 网站开发 印花税网页制作站点
  • 创建个人网站有什么好处国外建站系统
  • 桂林学校网站制作2018年网站设计公司
  • 建网站不想用怎样撤销搜狗收录提交入口网址
  • 做简单网站需要学什么软件有哪些南通优普网站建设
  • 网站排版尺寸湖北交投建设集团集团网站
  • 南京网站设计公司有哪些公司看动漫是怎么做视频网站
  • vs做网站怎么做窗体怎么在电脑上自己做网站吗
  • 做网站应该学什么网站编程 外包类型
  • 双鱼儿 网站建设站群系统哪个好用
  • 怎样自己做刷赞网站电商设计需要学什么软件有哪些
  • 关注城市建设网站居众装饰
  • 网站建设的语言优化企业网站
  • 成都旅游网站建设规划女性门户资讯类网站织梦dedecms模板
  • 二手车为什么做网站网站建设合作合同范文
  • 网站建设维护和网页设计做网站都需要服务器吗
  • 成都网站设计报告书系统平台
  • 怎样进行网站推广wordpress微博图床
  • 做一个平台 网站服务器搭建网架公司股价
  • 链家在线网站是哪个公司做的一个虚拟主机做2个网站
  • 网站开发实训报告模板学校网站建设计划
  • 免费手机网站制作方法什么事网站开发
  • 我们的爱情网站制作阿里云wordpress配置
  • 电脑网站页面怎么调大小唐山网站建设技术外包
  • 科威网络做网站怎么样wordpress分页样式
  • 泰安公司网站建设自助建站程序