upload-hub
一个支持多种存储方式的文件上传系统,提供简单易用的文件管理功能。
演示
项目简介
本项目是一个基于前后端分离架构的文件上传系统,支持多种存储方式,包括本地存储、阿里云 OSS 和 MinIO。用户可以通过直观的界面上传文件并管理已上传的文件。
技术栈
- 前端:
- Vue 2
- ElementUI
- 后端:
- JDK 1.8
- Spring Boot 2.3.12.RELEASE
- MySQL 8.0.26
- MyBatis-Plus
- 文件存储:
- Local(本地存储)
- OSS(阿里云对象存储)
- MinIO(分布式对象存储)
- 敬请期待。。。
开发者的话
尊敬的读者:
首先,请允许我向您致以诚挚的问候,并对项目中可能存在的不足表达由衷的歉意。作为一名主要专注于后端开发的工程师,我在前端设计与用户界面的呈现上仍处于学习与成长的阶段。因此,您在体验本项目时,可能会注意到页面布局不够精致、样式设计略显简朴、交互体验有待流畅,或是响应式设计尚未完美适配等问题。这些瑕疵,或许无法完全展现我对这个项目的完整构想,也可能在某种程度上影响您的使用体验。
我深知,一个优雅、直观的用户界面是产品体验不可或缺的一部分。为此,我正全力以赴提升前端开发技能,并积极探索更优的解决方案,以弥补现阶段的不足,逐步提升页面的美观度与实用性。
您的每一条意见与建议,对我来说都是弥足珍贵的财富。如果您在使用过程中有任何想法或改进建议,欢迎随时与我联系(邮箱:chenzhihua0123@gmail.com 或 GitHub Issues)。我承诺,将认真倾听您的需求,并尽我所能优化这个项目,力求为您带来一个更加美观、友好且高效的文件上传工具。
感谢您的耐心与包容。正是因为有您的支持,我才有动力不断前行。我坚信,随着时间的推移,我的技能会逐步精进,项目的品质也将日益提升。希望我们能一起见证这份作品从青涩走向成熟的旅程,每一个小小的进步都将成为我们共同的成就。
再次感谢您的理解与陪伴,期待与您携手共创更美好的体验!
此致,
czh-dev
2025年3月
快速开始
前端
-
克隆项目到本地:
git clone https://gitee.com/czh-dev/upload-hub.git cd upload-file-frontend -
安装依赖:
npm install -
启动开发服务器:
npm run serve -
访问应用: 在浏览器中打开 http://localhost:8080。
后端
- 进入后端目录:
cd upload-file-backend
-
配置环境:
确保已安装 JDK 1.8 和 Maven。 在 application.yml 中配置数据库和存储服务参数(见下方配置说明)。
-
构建并运行:
mvn clean install
mvn spring-boot:run
- 接口地址: 默认运行在 http://localhost:10086。
目录结构
.
├── upload-file-backend # 后端代码
│ ├── src # 源代码
│ └── data # 本地上传的数据文件
│ └── sql # SQL 脚本
│ └── pom.xml # Maven 配置文件
├── upload-file-frontend # 前端代码
│ ├── src # 源代码
│ ├── public # 静态资源
│ └── package.json # NPM 配置文件
└── README.md # 项目说明文档
前期准备
数据库
-
安装MySQL8.0或兼容版本
-
创建数据库upload_file:
CREATE DATABASE upload_file DEFAULT CHARACTER SET utf8mb4; -
执行
sql目录下的 SQL 脚本初始化表结构。
本地存储
-
修改数据库配置(
storage_config表):type=local
- Bucket:项目中data目录的绝对路径
MinIO
可选
创建MinIO容器
docker run -d --name upload-file \
-p 9000:9000 \
-p 9090:9090 \
-e MINIO_ROOT_USER=minio \
-e MINIO_ROOT_PASSWORD=minio123 \
-v E:\develop\MinIO\data:/data \
minio/minio server /data --console-address ":9090"
-
访问地址:http://localhost:9000(API) / http://localhost:9090(控制台)
-
默认凭证:用户名 minio,密码 minio123
-
存储路径:映射到本地 E:\develop\MinIO\data(Windows 示例,根据实际情况调整)。
-
创建Bucket,并且设置权限为
public -
修改数据库配置(
storage_config表):type=minio
- endpoint:http://localhost:9000
- access_key:minio
- secret_key:minio123
- bucket:你的Bucket名称
OSS(阿里云对象存储)
可选
-
开通服务:
- 登录 阿里云控制台 开通 OSS 服务。
- 创建 Bucket(如 upload-file-bucket)。
-
获取凭证:
- 在「访问控制 RAM」中创建 AccessKey,记录 AccessKey ID 和 AccessKey Secret。
-
设置跨域请求 (CORS):
-
修改数据库配置(
storage_config表):type=oss
- endpoint:你的OSS外网访问地域节点(OSS控制台概览处查看)
- access_key:你的AccessKey ID
- secret_key:你的AccessKey Secret
- bucket:你的Bucket名称
配置说明
后端配置文件 (application.yml)
server:
port: 10086
spring:
datasource:
url: jdbc:mysql://localhost:3306/upload-file?useSSL=false&serverTimezone=Asia/Shanghai
username: root
password: your-password
driver-class-name: com.mysql.cj.jdbc.Driver
servlet:
multipart:
max-file-size: 500MB
max-request-size: 500MB
main:
allow-bean-definition-overriding: true
logging:
level:
cn.czh.mapper: debug
功能特性
- 断点续传
- 文件分片
- 文件校验
- 文件秒传
- 多文件上传
- 支持多种存储方式切换
- 文件预览和管理
- 分页加载已上传文件
贡献
欢迎提交 Issue 或 Pull Request!

