mirror of
https://github.com/continew-org/continew-admin.git
synced 2025-09-11 06:57:12 +08:00
feat(system/file): 文件管理呈目录形式展示 (#151)
This commit is contained in:
@@ -71,27 +71,25 @@ public class FileRecorderImpl implements FileRecorder {
|
||||
? StrUtil.subBefore(originalFilename, StringConstants.DOT, true)
|
||||
: originalFilename);
|
||||
StorageDO storage = (StorageDO)fileInfo.getAttr().get(ClassUtil.getClassName(StorageDO.class, false));
|
||||
String domain = StrUtil.appendIfMissing(storage.getDomain(), StringConstants.SLASH);
|
||||
String filePath = StrUtil.appendIfMissing(fileInfo.getPath(), StringConstants.SLASH);
|
||||
// 处理fileInfo中存储的地址
|
||||
fileInfo.setUrl(URLUtil.normalize(domain + fileInfo.getPath() + fileInfo.getFilename()));
|
||||
fileInfo.setThUrl(URLUtil.normalize(domain + fileInfo.getPath() + fileInfo.getThFilename()));
|
||||
fileInfo.setUrl(URLUtil.normalize(storage.getDomain() + filePath + fileInfo.getFilename()));
|
||||
fileInfo.setThUrl(URLUtil.normalize(storage.getDomain() + filePath + fileInfo.getThFilename()));
|
||||
file.setUrl(fileInfo.getUrl());
|
||||
file.setSize(fileInfo.getSize());
|
||||
String absPath = fileInfo.getPath();
|
||||
if (absPath.endsWith(StringConstants.SLASH)) {
|
||||
String tempAbsPath = absPath.substring(0, absPath.length() - 1);
|
||||
String tempAbsPath = absPath.length() > 1 ? StrUtil.removeSuffix(absPath, StringConstants.SLASH) : absPath;
|
||||
String[] pathArr = tempAbsPath.split(StringConstants.SLASH);
|
||||
if (pathArr.length > 1) {
|
||||
file.setParentPath(pathArr[pathArr.length - 1]);
|
||||
} else {
|
||||
file.setParentPath(StringConstants.SLASH);
|
||||
}
|
||||
}
|
||||
file.setAbsPath(fileInfo.getPath());
|
||||
file.setAbsPath(tempAbsPath);
|
||||
file.setExtension(fileInfo.getExt());
|
||||
file.setType(FileTypeEnum.getByExtension(file.getExtension()));
|
||||
file.setContentType(fileInfo.getContentType());
|
||||
file.setMd5(fileInfo.getHashInfo().getMd5());
|
||||
file.setMd5(fileInfo.getHashInfo().getSha256());
|
||||
file.setMetadata(JSONUtil.toJsonStr(fileInfo.getMetadata()));
|
||||
file.setThumbnailUrl(fileInfo.getThUrl());
|
||||
file.setThumbnailSize(fileInfo.getThSize());
|
||||
|
@@ -44,4 +44,10 @@ public class FileReq implements Serializable {
|
||||
@NotBlank(message = "文件名称不能为空")
|
||||
@Length(max = 255, message = "文件名称长度不能超过 {max} 个字符")
|
||||
private String name;
|
||||
|
||||
/**
|
||||
* 上级目录
|
||||
*/
|
||||
@Schema(description = "上级目录", example = "25")
|
||||
private String parentPath;
|
||||
}
|
@@ -25,6 +25,7 @@ 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.model.resp.IdResp;
|
||||
import top.continew.starter.extension.crud.service.BaseService;
|
||||
|
||||
import java.time.LocalDate;
|
||||
@@ -94,4 +95,8 @@ public interface FileService extends BaseService<FileResp, FileResp, FileQuery,
|
||||
return today.getYear() + StringConstants.SLASH + today.getMonthValue() + StringConstants.SLASH + today
|
||||
.getDayOfMonth() + StringConstants.SLASH;
|
||||
}
|
||||
|
||||
FileResp check(String fileHash);
|
||||
|
||||
IdResp<Long> createDir(FileReq req);
|
||||
}
|
@@ -44,6 +44,7 @@ import top.continew.starter.core.constant.StringConstants;
|
||||
import top.continew.starter.core.util.StrUtils;
|
||||
import top.continew.starter.core.util.URLUtils;
|
||||
import top.continew.starter.core.validation.CheckUtils;
|
||||
import top.continew.starter.extension.crud.model.resp.IdResp;
|
||||
import top.continew.starter.extension.crud.service.BaseServiceImpl;
|
||||
|
||||
import java.util.List;
|
||||
@@ -91,7 +92,9 @@ public class FileServiceImpl extends BaseServiceImpl<FileMapper, FileDO, FileRes
|
||||
UploadPretreatment uploadPretreatment = fileStorageService.of(file)
|
||||
.setPlatform(storage.getCode())
|
||||
.setHashCalculatorMd5(true)
|
||||
.setHashCalculatorSha256(true)
|
||||
.putAttr(ClassUtil.getClassName(StorageDO.class, false), storage)
|
||||
// .setPath(StrUtil.removePrefix(path, StringConstants.SLASH));
|
||||
.setPath(path);
|
||||
// 图片文件生成缩略图
|
||||
if (FileTypeEnum.IMAGE.getExtensions().contains(FileNameUtil.extName(file.getOriginalFilename()))) {
|
||||
@@ -138,6 +141,40 @@ public class FileServiceImpl extends BaseServiceImpl<FileMapper, FileDO, FileRes
|
||||
return resp;
|
||||
}
|
||||
|
||||
@Override
|
||||
public FileResp check(String fileHash) {
|
||||
FileDO file = baseMapper.lambdaQuery().eq(FileDO::getMd5, fileHash).one();
|
||||
if (file != null) {
|
||||
return get(file.getId());
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public IdResp<Long> createDir(FileReq req) {
|
||||
StorageDO storage = storageService.getDefaultStorage();
|
||||
FileDO fileDo = new FileDO();
|
||||
fileDo.setName(req.getName());
|
||||
fileDo.setSize(0L);
|
||||
fileDo.setUrl(storage.getDomain() + req.getParentPath() + req.getName());
|
||||
String absPath = req.getParentPath();
|
||||
String tempAbsPath = absPath.length() > 1 ? StrUtil.removeSuffix(absPath, StringConstants.SLASH) : absPath;
|
||||
String[] pathArr = tempAbsPath.split(StringConstants.SLASH);
|
||||
if (pathArr.length > 1) {
|
||||
fileDo.setParentPath(pathArr[pathArr.length - 1]);
|
||||
} else {
|
||||
fileDo.setParentPath(StringConstants.SLASH);
|
||||
}
|
||||
fileDo.setAbsPath(tempAbsPath);
|
||||
fileDo.setExtension("dir");
|
||||
fileDo.setContentType("");
|
||||
fileDo.setType(FileTypeEnum.DIR);
|
||||
fileDo.setMd5("");
|
||||
fileDo.setStorageId(storage.getId());
|
||||
baseMapper.insert(fileDo);
|
||||
return new IdResp<>(fileDo.getId());
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void fill(Object obj) {
|
||||
super.fill(obj);
|
||||
|
@@ -35,6 +35,7 @@ import top.continew.admin.system.enums.OptionCategoryEnum;
|
||||
import top.continew.admin.system.model.query.*;
|
||||
import top.continew.admin.system.model.resp.file.FileUploadResp;
|
||||
import top.continew.admin.system.service.*;
|
||||
import top.continew.starter.core.constant.StringConstants;
|
||||
import top.continew.starter.core.validation.ValidationUtils;
|
||||
import top.continew.starter.extension.crud.model.query.SortQuery;
|
||||
import top.continew.starter.extension.crud.model.resp.LabelValueResp;
|
||||
@@ -66,9 +67,11 @@ public class CommonController {
|
||||
|
||||
@Operation(summary = "上传文件", description = "上传文件")
|
||||
@PostMapping("/file")
|
||||
public FileUploadResp upload(@NotNull(message = "文件不能为空") MultipartFile file) {
|
||||
public FileUploadResp upload(@NotNull(message = "文件不能为空") MultipartFile file, String path) {
|
||||
ValidationUtils.throwIf(file::isEmpty, "文件不能为空");
|
||||
FileInfo fileInfo = fileService.upload(file);
|
||||
FileInfo fileInfo = fileService.upload(file, StrUtil.isNotBlank(path)
|
||||
? StrUtil.appendIfMissing(path, StringConstants.SLASH)
|
||||
: "/");
|
||||
return FileUploadResp.builder()
|
||||
.id(fileInfo.getId())
|
||||
.url(fileInfo.getUrl())
|
||||
|
@@ -20,8 +20,7 @@ import cn.dev33.satoken.annotation.SaCheckPermission;
|
||||
import io.swagger.v3.oas.annotations.Operation;
|
||||
import io.swagger.v3.oas.annotations.tags.Tag;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.web.bind.annotation.GetMapping;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
import org.springframework.web.bind.annotation.*;
|
||||
import top.continew.admin.common.controller.BaseController;
|
||||
import top.continew.admin.system.model.query.FileQuery;
|
||||
import top.continew.admin.system.model.req.FileReq;
|
||||
@@ -30,6 +29,7 @@ import top.continew.admin.system.model.resp.file.FileStatisticsResp;
|
||||
import top.continew.admin.system.service.FileService;
|
||||
import top.continew.starter.extension.crud.annotation.CrudRequestMapping;
|
||||
import top.continew.starter.extension.crud.enums.Api;
|
||||
import top.continew.starter.extension.crud.model.resp.IdResp;
|
||||
import top.continew.starter.log.annotation.Log;
|
||||
|
||||
/**
|
||||
@@ -51,4 +51,19 @@ public class FileController extends BaseController<FileService, FileResp, FileRe
|
||||
public FileStatisticsResp statistics() {
|
||||
return baseService.statistics();
|
||||
}
|
||||
|
||||
@Log(ignore = true)
|
||||
@Operation(summary = "检测文件是否存在", description = "检测文件是否存在")
|
||||
@SaCheckPermission("system:file:check")
|
||||
@GetMapping("/check")
|
||||
public FileResp checkFile(String fileHash) {
|
||||
return baseService.check(fileHash);
|
||||
}
|
||||
|
||||
@Operation(summary = "创建文件夹", description = "创建文件夹")
|
||||
@ResponseBody
|
||||
@PostMapping("/createDir")
|
||||
public IdResp<Long> createDir(@RequestBody FileReq req) {
|
||||
return baseService.createDir(req);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user