# upload-hub **Repository Path**: luciferJD/upload-hub ## Basic Information - **Project Name**: upload-hub - **Description**: 本项目是一个基于前后端分离(SpringBoot/Vue2)的文件上传系统,支持多种存储方式(Local/MinIO/OSS),断点续传,分片上传,文件秒传 - **Primary Language**: Java - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 8 - **Created**: 2025-03-17 - **Last Updated**: 2025-03-17 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # upload-hub 一个支持多种存储方式的文件上传系统,提供简单易用的文件管理功能。 ## 演示 ![ev](images/ev_1.gif) ## 项目简介 本项目是一个基于前后端分离架构的文件上传系统,支持多种存储方式,包括本地存储、阿里云 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月 ## 快速开始 ### 前端 1. 克隆项目到本地: ```bash git clone https://gitee.com/czh-dev/upload-hub.git cd upload-file-frontend ``` 2. 安装依赖: ```bash npm install ``` 3. 启动开发服务器: ```bash npm run serve ``` 4. 访问应用: 在浏览器中打开 http://localhost:8080。 ### 后端 1. 进入后端目录: ```bash cd upload-file-backend ``` 2. 配置环境: 确保已安装 JDK 1.8 和 Maven。 在 application.yml 中配置数据库和存储服务参数(见下方配置说明)。 3. 构建并运行: ```bash mvn clean install mvn spring-boot:run ``` 4. 接口地址: 默认运行在 http://localhost:10086。 ## 目录结构 ```text . ├── upload-file-backend # 后端代码 │ ├── src # 源代码 │ └── data # 本地上传的数据文件 │ └── sql # SQL 脚本 │ └── pom.xml # Maven 配置文件 ├── upload-file-frontend # 前端代码 │ ├── src # 源代码 │ ├── public # 静态资源 │ └── package.json # NPM 配置文件 └── README.md # 项目说明文档 ``` ## 前期准备 ### 数据库 1. 安装MySQL8.0或兼容版本 2. 创建数据库upload_file: ```sql CREATE DATABASE upload_file DEFAULT CHARACTER SET utf8mb4; ``` 3. 执行 `sql` 目录下的 SQL 脚本初始化表结构。 ### 本地存储 - 修改数据库配置(`storage_config`表): **type=local** - Bucket:项目中data目录的绝对路径 ### MinIO > 可选 #### 创建MinIO容器 ```bash 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(阿里云对象存储) > 可选 1. 开通服务: - 登录 阿里云控制台 开通 OSS 服务。 - 创建 Bucket(如 upload-file-bucket)。 2. 获取凭证: - 在「访问控制 RAM」中创建 AccessKey,记录 AccessKey ID 和 AccessKey Secret。 3. 设置跨域请求 (CORS): - 进入 OSS 控制台,找到目标 Bucket。 - 在「基础设置」->「跨域设置」中添加规则: - 来源:*(或指定域名) - 允许 Methods:GET, POST, PUT - 允许 Headers:* - 示例截图: ![img.png](images/img.png) 4. 修改数据库配置(`storage_config`表): **type=oss** - endpoint:你的OSS外网访问地域节点(OSS控制台概览处查看) - access_key:你的AccessKey ID - secret_key:你的AccessKey Secret - bucket:你的Bucket名称 ## 配置说明 ### 后端配置文件 (application.yml) ```yaml 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!