From b701b92c8af86026b2536c65ec9161037e88a8d9 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期三, 12 三月 2025 18:26:41 +0800
Subject: [PATCH] 修改bug

---
 UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/ProblemServiceImpl.java |   32 +++++++++++++++++++++++++-------
 1 files changed, 25 insertions(+), 7 deletions(-)

diff --git a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/ProblemServiceImpl.java b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/ProblemServiceImpl.java
index b882259..bbacb35 100644
--- a/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/ProblemServiceImpl.java
+++ b/UserIGOTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/service/impl/ProblemServiceImpl.java
@@ -8,14 +8,14 @@
 import com.stylefeng.guns.modular.system.model.SensitiveWords;
 import com.stylefeng.guns.modular.system.service.IProblemService;
 import com.stylefeng.guns.modular.system.service.IUserInfoService;
+import com.stylefeng.guns.modular.system.util.DateUtil;
 import com.stylefeng.guns.modular.system.util.ResultUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
-import java.util.Date;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
+import java.util.stream.Collectors;
 
 
 @Service
@@ -44,12 +44,23 @@
         if(ToolUtil.isNotEmpty(content)){
             if(content.length() > 200){
                 language = userInfoService.queryLanguage(uid, language);
-                return ResultUtil.error(language == 1 ? "留言内容过长" : language == 2 ? "Message is too long" : "Le message est trop long");
+                return ResultUtil.error(language == 1 ? "留言内容过长" : language == 2 ? "Message-content is overlong." : "Le contenu du message est trop long.");
             }
             List<SensitiveWords> sensitiveWords = sensitiveWordsMapper.selectList(null);
+            List<String> list = Arrays.asList(content.split(" "));
             for(SensitiveWords s : sensitiveWords){
-                content = content.replaceAll(s.getContent(), "***");
+                List<String> str = new ArrayList<>();
+                String lowerCase = s.getContent().toLowerCase();
+                for (String s1 : list) {
+                    if(lowerCase.equals(s1.toLowerCase())){
+                        str.add("***");
+                    }else{
+                        str.add(s1);
+                    }
+                }
+                list = str;
             }
+            content = list.stream().collect(Collectors.joining(" "));
         }
 
         Problem problem = new Problem();
@@ -71,8 +82,15 @@
      * @throws Exception
      */
     @Override
-    public List<Map<String, Object>> queryProblems(Integer pageNum, Integer size, Integer uid) throws Exception {
+    public List<Map<String, Object>> queryProblems(Integer pageNum, Integer size, Integer uid, Integer language) throws Exception {
         pageNum = (pageNum - 1) * size;
-        return problemMapper.queryProblems(pageNum, size, uid);
+        List<Map<String, Object>> list = problemMapper.queryProblems(pageNum, size, uid);
+        for (Map<String, Object> map : list) {
+            if(null != map.get("insertTime")){
+                String insertTime = map.get("insertTime").toString();
+                map.put("insertTime", DateUtil.conversionFormat(language, insertTime));
+            }
+        }
+        return list;
     }
 }

--
Gitblit v1.7.1