使用国产开源企业级文件管理系统基于 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. 项目地址


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

相关推荐
小陈工1 小时前
Python安全编程实践:常见漏洞与防护措施
运维·开发语言·人工智能·python·安全·django·开源
AI成长日志8 小时前
【datawhale】hello agents开源课程学习记录第5章 智能体应用实践:低代码平台构建指南
学习·低代码·开源
cjy0001119 小时前
springboot的 nacos 配置获取不到导致启动失败及日志不输出问题
java·spring boot·后端
sheji341610 小时前
【开题答辩全过程】以 基于springboot的校园失物招领系统为例,包含答辩的问题和答案
java·spring boot·后端
程序员阿伦12 小时前
璋㈤鏈虹殑Java澶у巶闈㈣瘯璁帮細浠嶴pring Boot鍒癒ubernetes锛�3杞湡棰樺叏瑙f瀽锛�
spring boot·redis·kubernetes·aigc·java闈㈣瘯·寰湇鍔�·鐢靛晢绉掓潃
wuyikeer12 小时前
Spring BOOT 启动参数
java·spring boot·后端
zdl68613 小时前
springboot集成onlyoffice(部署+开发)
java·spring boot·后端
可观测性用观测云14 小时前
SpringBootAI 接入观测云 MCP 最佳实践
spring boot
F_U_N_14 小时前
大模型赋能下,开源知识库的核心特性与实践价值
人工智能·开源
BUG胡汉三14 小时前
自建在线文档编辑服务:基于 Collabora CODE + Spring Boot + Vue 3 的完整实现
vue.js·spring boot·后端·在线编辑