package com.fshop.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.fshop.common.PageHelper;
import com.fshop.common.R;
import com.fshop.dto.LoginUserDto;
import com.fshop.entity.Comment;
import com.fshop.entity.Evaluate;
import com.fshop.mapper.EvaluateMapper;
import com.fshop.service.CommentRepository;
import com.fshop.service.IEvaluateService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.fshop.util.JwtUtil;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.ArrayList;
import java.util.List;
import java.util.UUID;
/**
* <p>
* 订单评价表 服务实现类
* </p>
*
* @author dev
* @since 2024-04-23
*/
@Service
public class EvaluateServiceImpl extends ServiceImpl<EvaluateMapper, Evaluate> implements IEvaluateService {
@Autowired
private EvaluateMapper evaluateMapper;
@Autowired
private CommentRepository commentRepository;
@Override
public R<Page<Evaluate>> getAll(String token, Integer pageNum) {
// 解析token
LoginUserDto loginUser = JwtUtil.parseToken(token);
// 查询所有,user_id等于loginUser.getUserId,且status等于1的评论
QueryWrapper<Evaluate> wrapper = new QueryWrapper<>();
wrapper.eq("user_id", loginUser.getUserId()).eq("status", 1);
// 分页,每页显示10条评论
Page<Evaluate> page = new Page<>(pageNum, PageHelper.EVALUATE_PAGE_SIZE);
page = baseMapper.selectPage(page, wrapper);
if (page != null) {
return R.ok("查询成功", page);
}
return R.error("查询失败");
}
@Override
public R<String> removeEvaluate(String token, String evaluateId) {
// 先查询
LoginUserDto loginUser = JwtUtil.parseToken(token);
QueryWrapper<Evaluate> wrapper = new QueryWrapper<>();
wrapper.eq("user_id", loginUser.getUserId()).eq("evaluate_id", evaluateId).eq("status", 1);
Evaluate evaluate = baseMapper.selectOne(wrapper);
// System.out.println(evaluate);
if (evaluate != null) {
evaluate.setStatus(0);
int update = baseMapper.update(evaluate, wrapper);
if (update > 0) {
return R.ok("删除成功");
}
}
return R.error("查询失败");
}
@Override
public R<Evaluate> getById(String token, String evaluateId) {
// 解析token
LoginUserDto loginUser = JwtUtil.parseToken(token);
QueryWrapper<Evaluate> wrapper = new QueryWrapper<>();
wrapper.eq("user_id", loginUser.getUserId()).eq("evaluate_id", evaluateId).eq("status", 1);
Evaluate evaluate = baseMapper.selectOne(wrapper);
if (evaluate != null) {
return R.ok("查询成功", evaluate);
}
return R.error("查询失败");
}
//查询所有评论并返回用户ID、用户名称、用户头像以及用户评论
@Override
public R getEvaluateInfo(Integer fruitId,Integer currentPage, Integer queryCount) {
Integer preCurrentPage = (currentPage - 1) * queryCount;
return R.ok(evaluateMapper.getEvaluateInfo(fruitId,preCurrentPage , queryCount));
}
@Override
public R<String> saveEvaluate(String token, Evaluate evaluate){
LoginUserDto loginUser = JwtUtil.parseToken(token);
Integer tokenUserId = loginUser.getUserId();
Integer userId = evaluate.getUserId();
Comment comment = new Comment();
comment.setId(UUID.randomUUID().toString()); // 生成随机的 `_id`
evaluate.setEvaluateId(comment.getId());
comment.setFruitId(43);//假数据
comment.setScore(evaluate.getEvaluateScore());
comment.setStatus(1);
// 创建一个OriginalPoster对象并设置其字段值
Comment.OriginalPoster originalPoster = new Comment.OriginalPoster();
originalPoster.setUserId(evaluate.getUserId()); // 假设用户ID是123
originalPoster.setContent( new String(evaluate.getEvaluateInfo()));
LocalDateTime now = LocalDateTime.now();
// 对于LocalDateTime,应该直接使用ISO_LOCAL_DATE_TIME
DateTimeFormatter isoLocalDateTimeFormatter = DateTimeFormatter.ISO_LOCAL_DATE_TIME;
String iso8601String = now.format(isoLocalDateTimeFormatter);
originalPoster.setPostedAt(iso8601String); // 使用ISO 8601格式的日期时间字符串
comment.setOriginalPoster(originalPoster);
comment.setReplies(new ArrayList<>()); // 确保 `replies` 是一个空列表
commentRepository.save(comment);
// var evaluationData = {
// //userId: userId,
// myorderId: myorderId,
// evaluateInfo: evaluateInfo,
// evaluateScore: evaluateScore
// };
if (tokenUserId == null || userId == null) {
// 至少有一个ID是null,因此它们不相等
return R.error("添加失败");
} else if (tokenUserId != null && tokenUserId.equals(userId)) {
// 两个ID相等
evaluate.setStatus(1);
evaluate.setEvaluateCreateTime(LocalDateTime.now());
evaluate.setUpdateTime(LocalDateTime.now());
evaluate.setFruitId(43);
int insert = evaluateMapper.insert(evaluate);
if(insert > 0){
return R.ok("添加成功");
}else{
return R.error("添加失败");
}
} else {
// 两个ID都不为null,但不相等
return R.error("添加失败");
}
}
}
在IT行业中,WebSocket是一种在客户端和服务器之间建立长连接的协议,它允许双方进行全双工通信,即数据可以同时在两个方向上传输。在"002 递归评论 websocket消息推送"这个主题中,我们将深入探讨如何利用WebSocket技术实现递归评论的实时消息推送。 我们要理解什么是递归评论。在Web应用中,评论系统通常允许用户对评论进行回复,而回复的评论又可以被其他用户再次回复,形成层级结构,这就叫做递归评论。例如,在论坛或社交媒体中,一条评论下可以有多个子评论,这些子评论还可以有自己的子评论,以此类推,形成了一个树状结构。 WebSocket与递归评论的结合主要体现在实时性上。传统的HTTP协议是基于请求-响应模式的,如果要实现实时更新,服务器需要不断地轮询或者客户端频繁地发送请求,这既不高效也不节能。而WebSocket提供了一种持续连接的方式,一旦连接建立,就可以在需要时随时发送数据,非常适合用于实时消息推送,比如评论的新增、回复等操作。 要实现递归评论的WebSocket消息推送,我们需要做以下几步: 1. **服务器端设置**:服务器需要创建一个WebSocket服务端点,监听来自客户端的连接请求。当连接建立后,服务器需要存储每个客户端的连接,并且为每个连接创建一个唯一标识,以便后续的消息定向发送。 2. **客户端连接**:前端网页通过JavaScript的WebSocket API建立到服务器的WebSocket连接。一旦连接成功,客户端可以将用户的登录信息和当前浏览的评论区域ID发送给服务器,这样服务器就知道向哪个用户推送哪些评论的更新。 3. **事件监听**:在客户端,我们需要监听WebSocket的`onmessage`事件,当接收到服务器发送的数据时,根据数据内容更新评论展示,包括新的评论、回复以及评论的层级结构。 4. **递归评论数据结构**:为了处理递归评论,我们需要设计一个合适的数据结构来存储评论,可以使用JSON对象表示评论及其子评论,通过递归方式遍历和渲染这些数据。 5. **消息推送**:当服务器端接收到新的评论或回复时,它可以找到所有关注这个评论区域的客户端,然后向它们推送新数据。这里就需要用到WebSocket的`send()`方法来发送消息。 6. **错误处理**:无论是服务器还是客户端,都需要处理可能出现的网络中断或错误情况,比如重新连接、错误重试等。 7. **优化与安全**:考虑到性能和安全性,服务器可能需要限制并发连接数,对数据进行加密传输,以及防止恶意用户滥用WebSocket服务。 总结起来,"002 递归评论 websocket消息推送"涉及到的技术核心是利用WebSocket实现实时的消息推送,通过递归处理评论的层次结构,提供用户即时互动的体验。在实际开发中,我们需要综合考虑性能、安全性和用户体验,以构建高效、可靠的Web应用。














































- 1

- #完美解决问题
- #运行顺畅
- #内容详尽
- #全网独家
- #注释完整

- 粉丝: 2339
- 资源: 71
我的内容管理 展开
我的资源 快来上传第一个资源
我的收益
登录查看自己的收益我的积分 登录查看自己的积分
我的C币 登录后查看C币余额
我的收藏
我的下载
下载帮助


最新资源
- (源码)基于Arduino的5x8像素LED显示屏.zip
- swift-Swift资源
- (源码)基于STM32微控制器的LDC1000电感传感器测试项目.zip
- MATLAB chord chart-Matlab资源
- weChatRobot-机器人开发资源
- (源码)基于PHP的数据库自动备份工具.zip
- ToolsFx-Kotlin资源
- (源码)基于Java的接口自动化测试框架.zip
- AIOT人工智能物联网数据平台前端-AI人工智能资源
- (源码)基于JavaScript的前端自定义工具集.zip
- rust-ruoyi-Rust资源
- Book-Information-System-移动应用开发资源
- STC51-单片机开发资源
- (源码)基于Python的威胁情报收集工具.zip
- ruoyi-react-Typescript资源
- go支付合集-Go资源


