支持不限制大小,大文件分段批量上传功能(不受nginx /apache 上传大小限制)

大文件分段批量上传功能 (Large File Chunked Upload)

项目简介

这是一个实现大文件分段批量上传功能的示例项目。该项目使用 Spring Boot 框架,支持将大文件分割为多个小块进行上传,并在服务器端进行合并。

技术重点是前端使用了html 的: file.size 、file.slice 、xhr progress 事件.

以及在不打包vue情况下使用vue.

后端使用spring boot .

项目背景

nginx/apache 等服务默认不支持大文件上传,虽然支持配置,但是如果上传文件过大会长期占用一个长连接以及网络带宽,所以在单点form post upload 下大部分项目都会做文件上传限制,所以就有这个分断上传一个功能

网络上也已经也有很多现成的成功的例子以及文章,这里仅做一个另一种解决方法,仅供参考.

功能特性

  • 大文件分片上传:将大文件分成多个小块进行上传,避免一次性上传大文件导致的内存溢出或超时问题。
  • 文件合并:服务器端接收所有分片后,自动将分片合并为完整文件。
  • 上传进度跟踪:支持上传进度的实时跟踪。
  • 断点续传:支持上传中断后从断点继续上传。
  • 多文件批量上传:支持多个文件同时上传。

技术栈

  • Java 11+
  • Spring Boot 2.x
  • Maven
  • Vue.js (前端示例)

安装与使用

后端

  1. 确保已安装 JDK 11+ 和 Maven。

  2. 克隆项目到本地:

    bash 复制代码
    git clone https://github.com/pinke/upload-pro.git
  3. 进入项目目录并运行:

    bash 复制代码
    cd upload-pro
    mvn spring-boot:run
  4. 后端服务将启动在 http://localhost:8080/

前端

  1. 打开 http://localhost:8080/static/vue.html 文件。
  2. 在浏览器中打开该文件,即可使用上传功能。

API 文档

上传分片文件

  • URL : /api/upload
  • 方法 : POST
  • 请求体 : 包含文件分片的 multipart/form-data

合并文件

  • URL : /api/merge
  • 方法 : POST
  • 请求参数: 文件标识符和分片总数。
相关推荐
wendycwb27 分钟前
前端城市地址根据最后一级倒推,获取各层级id的方法
前端·vue.js·typescript
LuckyTHP28 分钟前
迁移shibboleth java获取shibboleth用户信息
java·开发语言
客卿12335 分钟前
数论===质数统计(暴力法,)
java·开发语言
华科易迅1 小时前
Spring 事务(注解)
java·数据库·spring
终端鹿1 小时前
Vue3 模板引用 (ref):操作 DOM 与子组件实例 从入门到精通
前端·javascript·vue.js
写代码的小阿帆1 小时前
Web工程结构解析:从MVC分层到DDD领域驱动
java·架构·mvc
东离与糖宝1 小时前
Java 26+Spring Boot 3.5,微服务启动从3秒压到0.8秒
java·人工智能
禹中一只鱼2 小时前
【力扣热题100学习笔记】 - 哈希
java·学习·leetcode·哈希算法
凌波粒2 小时前
LeetCode--349.两个数组的交集(哈希表)
java·算法·leetcode·散列表
于先生吖2 小时前
Java+SpringBoot 无人健身房物联网系统完整源码实现
java·spring boot·物联网