news 2026/3/16 13:06:54

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用国产开源企业级文件管理系统基于 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 安装步骤
gitclone https://gitee.com/dromara/free-fs.gitcdfree-fs mvn cleaninstall-DskipTests
5.3 数据库初始化
  • MySQL
    CREATEDATABASE`free-fs`CHARACTERSET'utf8mb4'COLLATE'utf8mb4_general_ci';
    导入_sql/mysql/free-fs.sql
  • PostgreSQL
    CREATEDATABASEfree-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. 启动服务:
    cdfs-admin mvn spring-boot:run
  3. 访问地址:
    • 服务地址:http://localhost:8080
    • API 文档:http://localhost:8080/swagger-ui.html
    • 默认账号:admin/admin

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-FSMinIONextcloudSeafile
技术栈Spring Boot 3.xGoPHPGo/C
定位文件管理后端对象存储完整网盘完整网盘
大文件上传分片/断点续传/秒传需自行实现支持支持
在线预览多格式支持需自行实现支持支持
多云存储插件化切换单一支持支持
权限管理Sa-Token 细粒度简单细粒度细粒度
部署难度中等(需数据库)中等中等
开源协议Apache 2.0AGPL v3AGPL v3GPL-3.0

8. 总结

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

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


9. 项目地址

  • 后端:https://gitee.com/dromara/free-fs
  • 前端:https://gitee.com/xddcode/free-fs-frontend

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/15 17:58:17

这次终于选对!巅峰之作的降AI率软件 —— 千笔·专业降AIGC智能体

在AI技术迅速渗透到学术写作领域的今天,越来越多的学生和研究者开始依赖AI工具来提升写作效率。然而,随之而来的“AI率超标”问题也日益凸显,成为论文审核中的隐形障碍。知网、维普、万方等查重系统不断升级算法,对AI生成内容的识…

作者头像 李华
网站建设 2026/3/15 17:58:25

Vite SSG:静态站点生成与Vue3性能优化的完美结合

Vite SSG:静态站点生成与Vue3性能优化的完美结合 【免费下载链接】vite-ssg Static site generation for Vue 3 on Vite 项目地址: https://gitcode.com/gh_mirrors/vi/vite-ssg 在现代Web开发中,静态站点生成(SSG:静态站点…

作者头像 李华
网站建设 2026/3/15 15:20:25

H5GG iOS修改引擎全解析:从技术原理到实战应用

H5GG iOS修改引擎全解析:从技术原理到实战应用 【免费下载链接】H5GG an iOS Mod Engine with JavaScript APIs & Html5 UI 项目地址: https://gitcode.com/gh_mirrors/h5/H5GG 初识H5GG:重新定义iOS功能扩展 H5GG(HTML5 GameGod…

作者头像 李华
网站建设 2026/3/15 14:39:28

系统内存优化工具深度评测:提升计算机性能的科学方法

系统内存优化工具深度评测:提升计算机性能的科学方法 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memreduct 1. …

作者头像 李华
网站建设 2026/3/15 14:39:30

‌量子钟在绝对零度下的运行误差分析

量子钟作为高精度计时设备,依赖于原子或离子的量子态跃迁来定义时间标准,其精度可达10^{-18}秒,广泛应用于卫星导航、金融交易和量子计算。然而,在接近绝对零度(-273.15C)的极端低温下,量子钟的…

作者头像 李华