From 3660c62eca4ec4bf3fda22607abdf6d702f06abd Mon Sep 17 00:00:00 2001
From: xin <1099200748@qq.com>
Date: Tue, 08 Jul 2025 16:34:33 +0800
Subject: [PATCH] 新增主键替代复合主键

---
 oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java |   57 ++++++++++++++++++++++++++-------------------------------
 1 files changed, 26 insertions(+), 31 deletions(-)

diff --git a/oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java b/oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java
index 0790373..d6ce91d 100644
--- a/oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java
+++ b/oying-system/src/main/java/com/oying/modules/system/service/impl/UserServiceImpl.java
@@ -2,6 +2,7 @@
 
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.oying.domain.BucketStorage;
 import com.oying.modules.security.service.OnlineUserService;
 import com.oying.modules.security.service.UserCacheManager;
 import com.oying.modules.system.domain.Job;
@@ -12,6 +13,7 @@
 import com.oying.modules.system.mapper.UserMapper;
 import com.oying.modules.system.mapper.UserRoleMapper;
 import com.oying.modules.system.service.UserService;
+import com.oying.service.BucketStorageService;
 import com.oying.utils.*;
 import lombok.RequiredArgsConstructor;
 import com.oying.config.properties.FileProperties;
@@ -20,9 +22,9 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.web.multipart.MultipartFile;
+
 import javax.servlet.http.HttpServletResponse;
 import javax.validation.constraints.NotBlank;
-import java.io.File;
 import java.io.IOException;
 import java.util.*;
 import java.util.concurrent.TimeUnit;
@@ -43,6 +45,7 @@
     private final RedisUtils redisUtils;
     private final UserCacheManager userCacheManager;
     private final OnlineUserService onlineUserService;
+    private final BucketStorageService bucketStorageService;
 
     @Override
     public PageResult<User> queryAll(UserQueryCriteria criteria, Page<Object> page) {
@@ -72,16 +75,15 @@
     @Override
     @Transactional(rollbackFor = Exception.class)
     public void create(User resources) {
-        resources.setDeptId(resources.getDept().getId());
         if (userMapper.findByUsername(resources.getUsername()) != null) {
             throw new EntityExistException(User.class, "username", resources.getUsername());
         }
-        if (userMapper.findByEmail(resources.getEmail()) != null) {
-            throw new EntityExistException(User.class, "email", resources.getEmail());
-        }
-        if (userMapper.findByPhone(resources.getPhone()) != null) {
-            throw new EntityExistException(User.class, "phone", resources.getPhone());
-        }
+//        if (userMapper.findByEmail(resources.getEmail()) != null) {
+//            throw new EntityExistException(User.class, "email", resources.getEmail());
+//        }
+//        if (userMapper.findByPhone(resources.getPhone()) != null) {
+//            throw new EntityExistException(User.class, "phone", resources.getPhone());
+//        }
         save(resources);
         // 保存用户岗位
         userJobMapper.insertData(resources.getId(), resources.getJobs());
@@ -94,17 +96,17 @@
     public void update(User resources) throws Exception {
         User user = getById(resources.getId());
         User user1 = userMapper.findByUsername(resources.getUsername());
-        User user2 = userMapper.findByEmail(resources.getEmail());
-        User user3 = userMapper.findByPhone(resources.getPhone());
+//        User user2 = userMapper.findByEmail(resources.getEmail());
+//        User user3 = userMapper.findByPhone(resources.getPhone());
         if (user1 != null && !user.getId().equals(user1.getId())) {
             throw new EntityExistException(User.class, "username", resources.getUsername());
         }
-        if (user2 != null && !user.getId().equals(user2.getId())) {
-            throw new EntityExistException(User.class, "email", resources.getEmail());
-        }
-        if (user3 != null && !user.getId().equals(user3.getId())) {
-            throw new EntityExistException(User.class, "phone", resources.getPhone());
-        }
+//        if (user2 != null && !user.getId().equals(user2.getId())) {
+//            throw new EntityExistException(User.class, "email", resources.getEmail());
+//        }
+//        if (user3 != null && !user.getId().equals(user3.getId())) {
+//            throw new EntityExistException(User.class, "phone", resources.getPhone());
+//        }
         // 如果用户的角色改变
         if (!resources.getRoles().equals(user.getRoles())) {
             redisUtils.del(CacheKey.DATA_USER + resources.getId());
@@ -112,20 +114,14 @@
             redisUtils.del(CacheKey.ROLE_AUTH + resources.getId());
             redisUtils.del(CacheKey.ROLE_USER + resources.getId());
         }
-        // 修改机构会影响 数据权限
-        if (!Objects.equals(resources.getDept(),user.getDept())) {
-            redisUtils.del(CacheKey.DATA_USER + resources.getId());
-        }
         // 如果用户被禁用,则清除用户登录信息
-        if(!resources.getEnabled()){
+        if (!resources.getEnabled()) {
             onlineUserService.kickOutForUsername(resources.getUsername());
         }
-        user.setDeptId(resources.getDept().getId());
         user.setUsername(resources.getUsername());
         user.setEmail(resources.getEmail());
         user.setEnabled(resources.getEnabled());
         user.setRoles(resources.getRoles());
-        user.setDept(resources.getDept());
         user.setJobs(resources.getJobs());
         user.setPhone(resources.getPhone());
         user.setNickName(resources.getNickName());
@@ -217,22 +213,22 @@
         // 验证文件上传的格式
         String image = "gif jpg png jpeg";
         String fileType = FileUtil.getExtensionName(multipartFile.getOriginalFilename());
-        if(fileType != null && !image.contains(fileType)){
-            throw new BadRequestException("文件格式错误!, 仅支持 " + image +" 格式");
+        if (fileType != null && !image.contains(fileType)) {
+            throw new BadRequestException("文件格式错误!, 仅支持 " + image + " 格式");
         }
         User user = userMapper.findByUsername(SecurityUtils.getCurrentUsername());
         String oldPath = user.getAvatarPath();
-        File file = FileUtil.upload(multipartFile, properties.getPath().getAvatar());
-        user.setAvatarPath(Objects.requireNonNull(file).getPath());
-        user.setAvatarName(file.getName());
+        BucketStorage bucketStorage = bucketStorageService.create(null, multipartFile);
+        user.setAvatarPath(bucketStorage.getPath());
+        user.setAvatarName(bucketStorage.getRealName());
         saveOrUpdate(user);
         if (StringUtils.isNotBlank(oldPath)) {
-            FileUtil.del(oldPath);
+            bucketStorageService.deleteById(oldPath);
         }
         @NotBlank String username = user.getUsername();
         flushCache(username);
         return new HashMap<String, String>(1) {{
-            put("avatar", file.getName());
+            put("avatar", bucketStorage.getRealName());
         }};
     }
 
@@ -251,7 +247,6 @@
             Map<String, Object> map = new LinkedHashMap<>();
             map.put("用户名", user.getUsername());
             map.put("角色", roles);
-            map.put("机构", user.getDept().getName());
             map.put("岗位", user.getJobs().stream().map(Job::getName).collect(Collectors.toList()));
             map.put("邮箱", user.getEmail());
             map.put("状态", user.getEnabled() ? "启用" : "禁用");

--
Gitblit v1.9.3