From eafe95f8cc03bc838970ad38a3ce1e44bedfcb5a Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Wed, 14 Jan 2026 09:41:56 +0800
Subject: [PATCH] feat(fileUpload): 添加公司隔离的文件上传功能
---
src/main/java/cc/mrbird/febs/ai/controller/fileUpload/FileUploadController.java | 36 +++++++++++++++++++++++++-----------
src/main/resources/templates/febs/views/modules/ai/fileUpload/index.html | 14 ++++++++++----
2 files changed, 35 insertions(+), 15 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/ai/controller/fileUpload/FileUploadController.java b/src/main/java/cc/mrbird/febs/ai/controller/fileUpload/FileUploadController.java
index 1f1c849..8170501 100644
--- a/src/main/java/cc/mrbird/febs/ai/controller/fileUpload/FileUploadController.java
+++ b/src/main/java/cc/mrbird/febs/ai/controller/fileUpload/FileUploadController.java
@@ -28,11 +28,11 @@
@RequestMapping(value = "/fileUpload")
public class FileUploadController extends BaseController {
- // @Value("${file.upload.dir}")
- private String uploadDir = "d:/upload/files";
+ // 基础上传目录
+ private String baseUploadDir = "/home/javaweb/webresource/ai";
- // @Value("${file.chunk.dir}")
- private String chunkDir = "d:/upload/chunks";
+ // 分片存储目录
+ private String baseChunkDir = "/home/javaweb/webresource/ai/chunks";
/**
* 上传文件分片
@@ -42,8 +42,11 @@
@RequestParam("fileName") String fileName,
@RequestParam("chunk") int chunk,
@RequestParam("chunks") int chunks,
- @RequestParam("fileMd5") String fileMd5) {
+ @RequestParam("fileMd5") String fileMd5,
+ @RequestParam("companyId") String companyId) {
try {
+ // 构建公司专属分片目录
+ String chunkDir = baseChunkDir + "/" + companyId;
// 确保分片目录存在
Path chunkPath = Paths.get(chunkDir, fileMd5);
if (!Files.exists(chunkPath)) {
@@ -67,8 +70,11 @@
@PostMapping("/mergeChunks")
public FebsResponse mergeChunks(@RequestParam("fileName") String fileName,
@RequestParam("fileMd5") String fileMd5,
- @RequestParam("chunks") int chunks) {
+ @RequestParam("chunks") int chunks,
+ @RequestParam("companyId") String companyId) {
try {
+ // 构建公司专属上传目录
+ String uploadDir = baseUploadDir + "/" + companyId;
// 确保上传目录存在
Path uploadPath = Paths.get(uploadDir);
if (!Files.exists(uploadPath)) {
@@ -79,6 +85,8 @@
String uniqueFileName = UUID.randomUUID().toString() + "_" + fileName;
Path targetFilePath = uploadPath.resolve(uniqueFileName);
+ // 构建公司专属分片目录
+ String chunkDir = baseChunkDir + "/" + companyId;
// 确保分片目录存在
Path chunkPath = Paths.get(chunkDir, fileMd5);
if (!Files.exists(chunkPath)) {
@@ -115,9 +123,12 @@
/**
* 播放视频文件
*/
- @GetMapping("/play/{fileName}")
- public void playVideo(@PathVariable("fileName") String fileName, HttpServletResponse response) {
+ @GetMapping("/play/{companyId}/{fileName}")
+ public void playVideo(@PathVariable("companyId") String companyId,
+ @PathVariable("fileName") String fileName,
+ HttpServletResponse response) {
try {
+ String uploadDir = baseUploadDir + "/" + companyId;
Path filePath = Paths.get(uploadDir, fileName);
if (!Files.exists(filePath)) {
response.setStatus(HttpStatus.NOT_FOUND.value());
@@ -147,9 +158,10 @@
/**
* 获取文件列表
*/
- @GetMapping("/list")
- public FebsResponse getFileList() {
+ @GetMapping("/list/{companyId}")
+ public FebsResponse getFileList(@PathVariable("companyId") String companyId) {
try {
+ String uploadDir = baseUploadDir + "/" + companyId;
Path uploadPath = Paths.get(uploadDir);
if (!Files.exists(uploadPath)) {
return new FebsResponse().data(new ArrayList<>());
@@ -181,8 +193,10 @@
* 删除文件
*/
@PostMapping("/delete")
- public FebsResponse deleteFile(@RequestParam("fileName") String fileName) {
+ public FebsResponse deleteFile(@RequestParam("fileName") String fileName,
+ @RequestParam("companyId") String companyId) {
try {
+ String uploadDir = baseUploadDir + "/" + companyId;
Path filePath = Paths.get(uploadDir, fileName);
if (Files.exists(filePath)) {
Files.delete(filePath);
diff --git a/src/main/resources/templates/febs/views/modules/ai/fileUpload/index.html b/src/main/resources/templates/febs/views/modules/ai/fileUpload/index.html
index 613b626..07d6317 100644
--- a/src/main/resources/templates/febs/views/modules/ai/fileUpload/index.html
+++ b/src/main/resources/templates/febs/views/modules/ai/fileUpload/index.html
@@ -310,6 +310,7 @@
var isUploading = false;
var startTime = 0;
var uploadedSize = 0;
+ var companyId = 'default'; // 默认公司ID,实际应用中应从session或URL参数获取
// 初始化
init();
@@ -483,6 +484,7 @@
formData.append('chunk', currentChunk);
formData.append('chunks', chunks);
formData.append('fileMd5', fileMd5);
+ formData.append('companyId', companyId);
$.ajax({
url: '/fileUpload/uploadChunk',
@@ -535,7 +537,8 @@
data: {
fileName: file.name,
fileMd5: fileMd5,
- chunks: chunks
+ chunks: chunks,
+ companyId: companyId
},
success: function(response) {
if (response.code === 200 || response.success) {
@@ -589,7 +592,7 @@
function refreshFileList() {
layer.msg('正在获取文件列表...', {icon: 16, time: 0});
$.ajax({
- url: '/fileUpload/list',
+ url: '/fileUpload/list/' + companyId,
type: 'GET',
success: function(response) {
layer.closeAll();
@@ -632,7 +635,7 @@
var videoPlayer = document.getElementById('videoPlayer');
var videoSource = document.getElementById('videoSource');
- videoSource.src = '/fileUpload/play/' + encodeURIComponent(fileName);
+ videoSource.src = '/fileUpload/play/' + companyId + '/' + encodeURIComponent(fileName);
videoPlayer.load();
videoPlayer.play();
});
@@ -646,7 +649,10 @@
$.ajax({
url: '/fileUpload/delete',
type: 'POST',
- data: {fileName: fileName},
+ data: {
+ fileName: fileName,
+ companyId: companyId
+ },
success: function(response) {
if (response.code === 200 || response.success) {
layer.msg('删除成功', {icon: 1});
--
Gitblit v1.9.1