使用国产开源企业级文件管理系统基于 Spring Boot 3.5.x + Sa-Token + MyBatis Flex

Free-FS:企业级文件管理系统后端


1. 项目概述

Free-FS 是一个基于 Spring Boot 3.5 + MyBatis Flex + Sa-Token + React/Vue 构建的企业级文件管理系统后端,提供大文件分片上传、多格式预览、多云存储支持、权限控制等功能,并配套 Vue 3 前端。


2. 核心术语

术语 含义
分片上传 将大文件切割为多个小块分别上传,网络中断后只需上传未完成的分片。
断点续传 记录上传进度,中断后从断点继续,无需重新上传整个文件。
秒传 通过文件哈希值(如 MD5)校验,若服务器已有相同文件,直接建立引用,无需重复上传。

3. 解决的问题

  • 大文件上传困难:传统方式网络中断需重新上传。
  • 存储平台绑定:单一云存储切换成本高。
  • 预览能力弱:仅支持少数格式,Office/PDF 预览需额外配置。
  • 权限管理粗糙:缺乏细粒度权限控制。
  • 部署复杂:依赖多、配置繁琐。

4. 核心功能

4.1 文件管理
  • 支持 列表视图网格视图
  • 文件分类、标签、搜索。
4.2 大文件上传与秒传
  • 前端分片并行上传,后端通过 SSE 实时推送进度
  • 断点续传:记录每个分片状态,续传从断点继续。
  • 秒传:计算文件哈希,服务器已有相同文件时直接建立引用。
4.3 多云存储插件化
  • SPI 插件化设计,存储能力抽象为统一接口。
  • 内置支持:本地存储、阿里云 OSS、七牛云 Kodo、AWS S3、RustFS。
  • 支持多存储平台并存,新增平台只需实现接口,无需修改主业务代码。
4.4 在线预览
类型 支持格式
图片 JPG/PNG/GIF/WebP/SVG 等
Office 文档 DOC/DOCX/XLS/XLSX/PPT/PPTX(需 LibreOffice)
文本代码 30+ 种编程语言语法高亮
音视频 流式播放
压缩包 目录结构查看
4.5 权限与安全
  • 基于 Sa-Token 的权限认证,支持 JWT 无状态会话。
  • 细粒度权限控制:文件查看、下载、编辑、删除等操作。
4.6 文件分享与回收站
  • 分享模式:公开链接、授权码(可设有效期、访问次数)。
  • 回收站:支持批量还原、永久删除、自动清理。

5. 安装与快速上手

5.1 环境要求
  • JDK 17+
  • Maven 3.8+
  • MySQL 8.0+ 或 PostgreSQL 14+
  • Redis
  • LibreOffice(可选,用于 Office 预览)
5.2 安装步骤
bash 复制代码
git clone https://gitee.com/dromara/free-fs.git
cd free-fs
mvn clean install -DskipTests
5.3 数据库初始化
  • MySQL

    sql 复制代码
    CREATE DATABASE `free-fs` CHARACTER SET 'utf8mb4' COLLATE 'utf8mb4_general_ci';

    导入 _sql/mysql/free-fs.sql

  • PostgreSQL

    sql 复制代码
    CREATE DATABASE free-fs ENCODING 'UTF8' LC_COLLATE='zh_CN.UTF-8' LC_CTYPE='zh_CN.UTF-8';

    导入 _sql/postgresql/free-fs_pg.sql

5.4 配置与运行
  1. 修改 fs-admin/src/main/resources/application-dev.yml 中的数据库和 Redis 配置。

  2. 启动服务:

    bash 复制代码
    cd fs-admin
    mvn spring-boot:run
  3. 访问地址:


6. 技术架构

6.1 技术栈
  • 后端:Spring Boot 3.5.4 + MyBatis Flex(ORM) + Sa-Token(认证)
  • 数据库:MySQL 8.0+ / PostgreSQL 14+
  • 缓存:Caffeine(本地缓存)+ Redis(分布式缓存)
  • 存储插件:SPI 设计,支持多云存储扩展
6.2 项目结构
复制代码
free-fs/
├── fs-admin           # 管理后台
├── fs-api            # API 模块
├── fs-common         # 通用工具
├── storage-plugin-core   # 存储插件接口
├── storage-plugin-local  # 本地存储实现
└── ...               # 其他存储插件

7. 与其他方案对比

维度 Free-FS MinIO Nextcloud Seafile
技术栈 Spring Boot 3.x Go PHP Go/C
定位 文件管理后端 对象存储 完整网盘 完整网盘
大文件上传 分片/断点续传/秒传 需自行实现 支持 支持
在线预览 多格式支持 需自行实现 支持 支持
多云存储 插件化切换 单一 支持 支持
权限管理 Sa-Token 细粒度 简单 细粒度 细粒度
部署难度 中等(需数据库) 中等 中等
开源协议 Apache 2.0 AGPL v3 AGPL v3 GPL-3.0

8. 总结

优势
  • 功能完整,开箱即用。
  • 大文件上传(分片/断点续传/秒传)。
  • 插件化存储扩展,支持多云切换。
  • 多格式在线预览。
  • Sa-Token 细粒度权限管理。
  • Apache 2.0 开源协议。
局限
  • 需部署数据库(MySQL/PostgreSQL + Redis)。
  • Office 预览需配置 LibreOffice。
适用场景
  • 企业级文件管理系统搭建。
  • 需要多云存储支持。
  • 需要大文件上传与预览能力。
建议

先部署基础版本跑通上传下载流程,再根据需要接入云存储和配置预览功能。


9. 项目地址


提示:建议先体验基础功能,再逐步接入云存储与高级配置。

相关推荐
青云计划8 小时前
知光项目知文发布模块
java·后端·spring·mybatis
冬奇Lab8 小时前
一天一个开源项目(第20篇):NanoBot - 轻量级AI Agent框架,极简高效的智能体构建工具
人工智能·开源·agent
+VX:Fegn089511 小时前
计算机毕业设计|基于springboot + vue鲜花商城系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
识君啊11 小时前
SpringBoot 事务管理解析 - @Transactional 的正确用法与常见坑
java·数据库·spring boot·后端
CaracalTiger12 小时前
如何解决Unexpected token ‘<’, “<!doctype “… is not valid JSON 报错问题
java·开发语言·jvm·spring boot·python·spring cloud·json
苏渡苇12 小时前
Java + Redis + MySQL:工业时序数据缓存与持久化实战(适配高频采集场景)
java·spring boot·redis·后端·spring·缓存·架构
a11177612 小时前
几何占领 原创网页小游戏(html开源)
前端·开源·html
Hx_Ma1613 小时前
Springboot整合mybatis注解版
java·spring boot·mybatis
t***442313 小时前
Spring boot整合quartz方法
java·前端·spring boot
蛐蛐蜉蝣耶14 小时前
互联网大厂Java面试实录:当严肃面试官遇上搞笑程序员谢飞机
spring boot·微服务·java面试·电商系统·分布式系统·技术面试·程序员面试