feat(system): 添加文件管理模块及权限控制功能

- 新增文件主信息实体类SysFile,包含文件名、路径、大小等属性
- 创建文件可见用户关联实体SysFileVisibleUser,实现文件权限控制
- 添加文件服务接口ISysFileService和实现类SysFileServiceImpl
- 实现文件可见用户服务接口ISysFileVisibleUserService及其实现
- 创建文件控制器SysFileController,提供文件CRUD操作接口
- 添加文件可见用户控制器SysFileVisibleUserController
- 配置文件和关联表的MyBatis映射及XML配置文件
- 定义文件和关联信息的业务对象BO、视图对象VO类
- 实现文件列表分页查询、详情查看、新增修改删除功能
- 支持文件权限分配给指定用户的多对多关联功能
This commit is contained in:
2026-06-30 10:01:18 +08:00
parent dbcc28fb80
commit d4b5bc7041
16 changed files with 953 additions and 0 deletions

View File

@@ -0,0 +1,99 @@
package com.klp.web.controller.system;
import java.util.List;
import java.util.Arrays;
import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.annotation.Log;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil;
import com.klp.system.domain.vo.SysFileVo;
import com.klp.system.domain.bo.SysFileBo;
import com.klp.system.service.ISysFileService;
import com.klp.common.core.page.TableDataInfo;
/**
* 文件主信息
*
* @author klp
* @date 2026-06-30
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/system/file")
public class SysFileController extends BaseController {
private final ISysFileService iSysFileService;
/**
* 查询文件主信息列表
*/
@GetMapping("/list")
public TableDataInfo<SysFileVo> list(SysFileBo bo, PageQuery pageQuery) {
return iSysFileService.queryPageList(bo, pageQuery);
}
/**
* 导出文件主信息列表
*/
@Log(title = "文件主信息", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(SysFileBo bo, HttpServletResponse response) {
List<SysFileVo> list = iSysFileService.queryList(bo);
ExcelUtil.exportExcel(list, "文件主信息", SysFileVo.class, response);
}
/**
* 获取文件主信息详细信息
*
* @param fileId 主键
*/
@GetMapping("/{fileId}")
public R<SysFileVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long fileId) {
return R.ok(iSysFileService.queryById(fileId));
}
/**
* 新增文件主信息
*/
@Log(title = "文件主信息", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody SysFileBo bo) {
return toAjax(iSysFileService.insertByBo(bo));
}
/**
* 修改文件主信息
*/
@Log(title = "文件主信息", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody SysFileBo bo) {
return toAjax(iSysFileService.updateByBo(bo));
}
/**
* 删除文件主信息
*
* @param fileIds 主键串
*/
@Log(title = "文件主信息", businessType = BusinessType.DELETE)
@DeleteMapping("/{fileIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] fileIds) {
return toAjax(iSysFileService.deleteWithValidByIds(Arrays.asList(fileIds), true));
}
}

View File

@@ -0,0 +1,99 @@
package com.klp.web.controller.system;
import java.util.List;
import java.util.Arrays;
import lombok.RequiredArgsConstructor;
import javax.servlet.http.HttpServletResponse;
import javax.validation.constraints.*;
import org.springframework.web.bind.annotation.*;
import org.springframework.validation.annotation.Validated;
import com.klp.common.annotation.RepeatSubmit;
import com.klp.common.annotation.Log;
import com.klp.common.core.controller.BaseController;
import com.klp.common.core.domain.PageQuery;
import com.klp.common.core.domain.R;
import com.klp.common.core.validate.AddGroup;
import com.klp.common.core.validate.EditGroup;
import com.klp.common.enums.BusinessType;
import com.klp.common.utils.poi.ExcelUtil;
import com.klp.system.domain.vo.SysFileVisibleUserVo;
import com.klp.system.domain.bo.SysFileVisibleUserBo;
import com.klp.system.service.ISysFileVisibleUserService;
import com.klp.common.core.page.TableDataInfo;
/**
* 私有文件可见用户多对多关联
*
* @author klp
* @date 2026-06-30
*/
@Validated
@RequiredArgsConstructor
@RestController
@RequestMapping("/system/fileVisibleUser")
public class SysFileVisibleUserController extends BaseController {
private final ISysFileVisibleUserService iSysFileVisibleUserService;
/**
* 查询私有文件可见用户多对多关联列表
*/
@GetMapping("/list")
public TableDataInfo<SysFileVisibleUserVo> list(SysFileVisibleUserBo bo, PageQuery pageQuery) {
return iSysFileVisibleUserService.queryPageList(bo, pageQuery);
}
/**
* 导出私有文件可见用户多对多关联列表
*/
@Log(title = "私有文件可见用户多对多关联", businessType = BusinessType.EXPORT)
@PostMapping("/export")
public void export(SysFileVisibleUserBo bo, HttpServletResponse response) {
List<SysFileVisibleUserVo> list = iSysFileVisibleUserService.queryList(bo);
ExcelUtil.exportExcel(list, "私有文件可见用户多对多关联", SysFileVisibleUserVo.class, response);
}
/**
* 获取私有文件可见用户多对多关联详细信息
*
* @param visibleId 主键
*/
@GetMapping("/{visibleId}")
public R<SysFileVisibleUserVo> getInfo(@NotNull(message = "主键不能为空")
@PathVariable Long visibleId) {
return R.ok(iSysFileVisibleUserService.queryById(visibleId));
}
/**
* 新增私有文件可见用户多对多关联
*/
@Log(title = "私有文件可见用户多对多关联", businessType = BusinessType.INSERT)
@RepeatSubmit()
@PostMapping()
public R<Void> add(@Validated(AddGroup.class) @RequestBody SysFileVisibleUserBo bo) {
return toAjax(iSysFileVisibleUserService.insertByBo(bo));
}
/**
* 修改私有文件可见用户多对多关联
*/
@Log(title = "私有文件可见用户多对多关联", businessType = BusinessType.UPDATE)
@RepeatSubmit()
@PutMapping()
public R<Void> edit(@Validated(EditGroup.class) @RequestBody SysFileVisibleUserBo bo) {
return toAjax(iSysFileVisibleUserService.updateByBo(bo));
}
/**
* 删除私有文件可见用户多对多关联
*
* @param visibleIds 主键串
*/
@Log(title = "私有文件可见用户多对多关联", businessType = BusinessType.DELETE)
@DeleteMapping("/{visibleIds}")
public R<Void> remove(@NotEmpty(message = "主键不能为空")
@PathVariable Long[] visibleIds) {
return toAjax(iSysFileVisibleUserService.deleteWithValidByIds(Arrays.asList(visibleIds), true));
}
}