mirror of
				https://github.com/continew-org/continew-admin.git
				synced 2025-10-26 06:57:08 +08:00 
			
		
		
		
	refactor(system/file): 优化文件相关代码
This commit is contained in:
		| @@ -14,7 +14,7 @@ | ||||
|  * limitations under the License. | ||||
|  */ | ||||
| 
 | ||||
| package top.continew.admin.system.config.container; | ||||
| package top.continew.admin.system.config.file; | ||||
| 
 | ||||
| import cn.crane4j.core.container.Container; | ||||
| import lombok.RequiredArgsConstructor; | ||||
| @@ -29,19 +29,26 @@ import java.util.Map; | ||||
| import java.util.function.Function; | ||||
| import java.util.stream.Collectors; | ||||
| 
 | ||||
| /** | ||||
|  * 文件信息填充容器 | ||||
|  * | ||||
|  * @author luoqiz | ||||
|  * @since 2025/3/12 18:11 | ||||
|  */ | ||||
| @Component | ||||
| @RequiredArgsConstructor | ||||
| public class FileInfoContainer implements Container<Long> { | ||||
| 
 | ||||
|     private final FileService fileService; | ||||
| 
 | ||||
|     @Override | ||||
|     public String getNamespace() { | ||||
|         return ContainerConstants.FILE_INFO; | ||||
|     } | ||||
| 
 | ||||
|     @Override | ||||
|     public Map<Long, FileDO> get(Collection<Long> ids) { | ||||
|         List<FileDO> list = fileService.listByIds(ids); | ||||
|         return list.stream().collect(Collectors.toMap(FileDO::getId, Function.identity())); | ||||
|     } | ||||
| 
 | ||||
| } | ||||
| @@ -18,15 +18,16 @@ package top.continew.admin.system.service; | ||||
|  | ||||
| import org.dromara.x.file.storage.core.FileInfo; | ||||
| import org.springframework.web.multipart.MultipartFile; | ||||
| import top.continew.admin.common.constant.SysFileConstants; | ||||
| import top.continew.admin.system.model.entity.FileDO; | ||||
| import top.continew.admin.system.model.query.FileQuery; | ||||
| import top.continew.admin.system.model.req.FileReq; | ||||
| import top.continew.admin.system.model.resp.file.FileResp; | ||||
| import top.continew.admin.system.model.resp.file.FileStatisticsResp; | ||||
| import top.continew.starter.core.constant.StringConstants; | ||||
| import top.continew.starter.data.mp.service.IService; | ||||
| import top.continew.starter.extension.crud.service.BaseService; | ||||
|  | ||||
| import java.time.LocalDate; | ||||
| import java.util.List; | ||||
|  | ||||
| /** | ||||
| @@ -44,13 +45,14 @@ public interface FileService extends BaseService<FileResp, FileResp, FileQuery, | ||||
|      * @return 文件信息 | ||||
|      */ | ||||
|     default FileInfo upload(MultipartFile file) { | ||||
|         return upload(file, SysFileConstants.getDefaultFilePath(), null); | ||||
|         return upload(file, getDefaultFilePath(), null); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * 上传到默认存储 | ||||
|      * | ||||
|      * @param file 文件信息 | ||||
|      * @param path 文件路径 | ||||
|      * @return 文件信息 | ||||
|      */ | ||||
|     default FileInfo upload(MultipartFile file, String path) { | ||||
| @@ -81,4 +83,15 @@ public interface FileService extends BaseService<FileResp, FileResp, FileQuery, | ||||
|      * @return 资源统计信息 | ||||
|      */ | ||||
|     FileStatisticsResp statistics(); | ||||
|  | ||||
|     /** | ||||
|      * 获取默认文件路径 | ||||
|      * | ||||
|      * @return 默认文件路径 | ||||
|      */ | ||||
|     default String getDefaultFilePath() { | ||||
|         LocalDate today = LocalDate.now(); | ||||
|         return today.getYear() + StringConstants.SLASH + today.getMonthValue() + StringConstants.SLASH + today | ||||
|             .getDayOfMonth() + StringConstants.SLASH; | ||||
|     } | ||||
| } | ||||
| @@ -57,7 +57,6 @@ import org.springframework.web.multipart.MultipartFile; | ||||
| import top.continew.admin.auth.service.OnlineUserService; | ||||
| import top.continew.admin.common.constant.CacheConstants; | ||||
| import top.continew.admin.common.constant.SysConstants; | ||||
| import top.continew.admin.common.constant.SysFileConstants; | ||||
| import top.continew.admin.common.context.UserContext; | ||||
| import top.continew.admin.common.context.UserContextHolder; | ||||
| import top.continew.admin.common.enums.DisEnableStatusEnum; | ||||
| @@ -122,6 +121,8 @@ public class UserServiceImpl extends BaseServiceImpl<UserMapper, UserDO, UserRes | ||||
|     private DeptService deptService; | ||||
|     @Value("${avatar.support-suffix}") | ||||
|     private String[] avatarSupportSuffix; | ||||
|     @Value("${avatar.path}") | ||||
|     private String avatarPath; | ||||
|  | ||||
|     @Override | ||||
|     public PageResp<UserResp> page(UserQuery query, PageQuery pageQuery) { | ||||
| @@ -389,11 +390,18 @@ public class UserServiceImpl extends BaseServiceImpl<UserMapper, UserDO, UserRes | ||||
|         String avatarImageType = FileNameUtil.extName(avatarFile.getOriginalFilename()); | ||||
|         CheckUtils.throwIf(!StrUtil.equalsAnyIgnoreCase(avatarImageType, avatarSupportSuffix), "头像仅支持 {} 格式的图片", String | ||||
|             .join(StringConstants.CHINESE_COMMA, avatarSupportSuffix)); | ||||
|         FileInfo fileInfo = fileService.upload(avatarFile, SysFileConstants.USER_AVATAR_PATH); | ||||
|         UserDO userInfo = getById(id); | ||||
|         fileStorageService.delete(userInfo.getAvatar()); | ||||
|         baseMapper.lambdaUpdate().set(UserDO::getAvatar, fileInfo.getUrl()).eq(UserDO::getId, id).update(); | ||||
|         return fileInfo.getUrl(); | ||||
|         // 上传新头像 | ||||
|         UserDO user = super.getById(id); | ||||
|         FileInfo fileInfo = fileService.upload(avatarFile, avatarPath); | ||||
|         // 更新用户头像 | ||||
|         String newAvatar = fileInfo.getUrl(); | ||||
|         baseMapper.lambdaUpdate().set(UserDO::getAvatar, newAvatar).eq(UserDO::getId, id).update(); | ||||
|         // 删除原头像 | ||||
|         String oldAvatar = user.getAvatar(); | ||||
|         if (StrUtil.isNotBlank(oldAvatar)) { | ||||
|             fileStorageService.delete(oldAvatar); | ||||
|         } | ||||
|         return newAvatar; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|   | ||||
		Reference in New Issue
	
	Block a user