From bd3128deee35126344bc4d14a1749409859f9c4f Mon Sep 17 00:00:00 2001
From: zj <1772600164@qq.com>
Date: Fri, 09 Aug 2024 02:38:01 +0800
Subject: [PATCH] 1

---
 websocketSerivce/src/main/java/org/example/controller/UserController.java |   67 ++++++++++++++++++++++++++++++++-
 1 files changed, 65 insertions(+), 2 deletions(-)

diff --git a/websocketSerivce/src/main/java/org/example/controller/UserController.java b/websocketSerivce/src/main/java/org/example/controller/UserController.java
index e5d11b1..c8293de 100644
--- a/websocketSerivce/src/main/java/org/example/controller/UserController.java
+++ b/websocketSerivce/src/main/java/org/example/controller/UserController.java
@@ -73,6 +73,7 @@
                 map.put("user",user);
                 map.put("menu",menus);
                 extracted(account, request);
+                RedisUtil.set(user.getId().toString(),token);
                 return ServerResponse.createBySuccess(map);
             }
 
@@ -92,8 +93,7 @@
             List<Menu> menuList = menus.stream().filter(f -> f.getIsRoot() == 0).collect(Collectors.toList());
             map.put("menu",menuList);
             map.put("user",user);
-            String key = "user_";
-            RedisUtil.set(key+user.getId(),token);
+            RedisUtil.set(user.getId().toString(),token);
 
             extracted(account, request);
             return ServerResponse.createBySuccess(map);
@@ -230,4 +230,67 @@
                 .orderByDesc(Log::getLoginTime));
         return ServerResponse.createBySuccess(pageList);
     }
+
+    @GetMapping("/addMark")
+    public ServerResponse addMark(@RequestParam(value = "favorites") String favorites,
+                                  HttpServletRequest request) {
+        String token = request.getHeader("token");
+        User user = JwtUtil.verify(token);
+
+        if (user == null) {
+            // 处理用户验证失败的情况,例如返回未授权错误
+            return ServerResponse.createByErrorMsg("标记失败");
+        }
+
+        String mark = RedisUtil.get(user.getId() + "_mark");
+
+        if (StringUtils.isNotEmpty(mark)) {
+            // 使用 StringJoiner 或者 StringBuilder 来拼接字符串
+            mark += "," + favorites;
+        } else {
+            mark = favorites;
+        }
+
+        // 更新 Redis 中的标记
+        RedisUtil.set(user.getId() + "_mark", mark);
+
+        // 返回操作成功的响应
+        return ServerResponse.createBySuccess("标记成功");
+    }
+
+    @GetMapping("/deleteMark")
+    @ResponseBody
+    public ServerResponse deleteMark(@RequestParam(value = "favorites") String favorites,
+                                     HttpServletRequest request) {
+        String token = request.getHeader("token");
+        User user = JwtUtil.verify(token);
+
+        String mark = RedisUtil.get(user.getId() + "_mark");
+
+        if (StringUtils.isNotEmpty(mark)) {
+            // 使用逗号分隔符将标记分割成数组
+            String[] marks = mark.split(",");
+
+            // 创建一个新的标记列表,用于存储没有要删除的标记
+            List<String> updatedMarks = new ArrayList<>();
+
+            // 遍历现有的标记,将不等于要删除的标记加入新列表
+            for (String m : marks) {
+                if (!m.equals(favorites)) {
+                    updatedMarks.add(m);
+                }
+            }
+
+            // 将新的标记列表转换为逗号分隔的字符串
+            mark = String.join(",", updatedMarks);
+
+            // 更新 Redis 中的标记
+            RedisUtil.set(user.getId() + "_mark", mark);
+
+
+        }
+        // 返回操作成功的响应
+        return ServerResponse.createBySuccess("取消标记成功");
+    }
+
 }

--
Gitblit v1.9.3