Spring Boot文件上传功能实现详解

一、文件上传核心实现
java 复制代码
// PersonController.java
@PostMapping("/excelUpload")
public Result excelUpload(@RequestParam("uploadExcel") MultipipartFile multipartFile) {
    // 1. 获取原始文件名
    String fileName = multipartFile.getOriginalFilename();
    
    // 2. 构建存储路径
    Path path = Paths.get(excelpath + fileName);
    System.out.println("文件保存路径: " + path);
    
    // 3. 保存文件到服务器
    try {
        multipartFile.transferTo(path);
    } catch (IOException e) {
        e.printStackTrace();
    }
    
    // 4. 返回成功响应
    return Result.ok().put("data", fileName);
}
二、关键技术组件解析
  1. MultipartFile接口

    • Spring提供的文件上传处理接口

    • 核心方法:

      • getOriginalFilename(): 获取原始文件名

      • transferTo(): 将文件保存到指定位置

      • getInputStream(): 获取文件输入流

  2. 文件路径配置

    bash 复制代码
    # application.properties
    file-upload.url=D:/javacode/community_vue/community/FileXls/
    • 通过@Value注解注入配置路径

      bash 复制代码
      @Value("${file-upload.url}")
      private String excelpath;
    • 路径处理工具

      • Paths.get(): 构建平台无关的文件路径

      • transferTo(): 将上传文件保存到指定位置

三、静态资源映射配置
java 复制代码
// WebMvVCconfigruation.java
@Configuration
public class WebMvVCconfigruation implements WebMvcConfigurer {
    @Value("${file-upload.url}")
    private String excelPath;

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        // 映射/FileXls/**到本地文件系统
        registry.addResourceHandler("/FileXls/**")
                .addResourceLocations("file:" + excelPath);
    }
}
四、完整上传流程
五、前端调用示例
html 复制代码
<!-- HTML表单 -->
<form action="/sys/person/excelUpload" method="post" enctype="multipart/form-data">
    <input type="file" name="uploadExcel" accept=".xls,.xlsx">
    <button type="submit">上传Excel</button>
</form>

<!-- AJAX调用 -->
<script>
function uploadExcel(file) {
    const formData = new FormData();
    formData.append('uploadExcel', file);
    
    fetch('/sys/person/excelUpload', {
        method: 'POST',
        body: formData
    })
    .then(response => response.json())
    .then(data => {
        console.log('上传成功:', data.data);
        // 访问上传的文件: http://localhost:8080/FileXls/filename.xls
    });
}
</script>
六、中文文件名乱码
html 复制代码
// 在application.properties中添加
spring.servlet.encoding.force=true
spring.servlet.encoding.charset=UTF-8
七、大文件上传优化
java 复制代码
// 分块上传处理
@PostMapping("/chunkUpload")
public Result chunkUpload(@RequestParam Chunk chunk) {
    // 实现分片合并逻辑
}

完整实现代码已包含在提供的Java文件中,通过结合Controller层的上传处理和MVC配置层的静态资源映射,实现了完整的文件上传和访问解决方案。

相关推荐
野犬寒鸦7 分钟前
从零起步学习并发编程 || 第四章:synchronized底层源码级讲解及项目实战应用案例
java·服务器·开发语言·jvm·后端·学习·面试
!停8 分钟前
数据结构二叉树——堆
java·数据结构·算法
virus59458 小时前
悟空CRM mybatis-3.5.3-mapper.dtd错误解决方案
java·开发语言·mybatis
计算机毕设VX:Fegn08958 小时前
计算机毕业设计|基于springboot + vue蛋糕店管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
没差c9 小时前
springboot集成flyway
java·spring boot·后端
时艰.9 小时前
Java 并发编程之 CAS 与 Atomic 原子操作类
java·开发语言
编程彩机10 小时前
互联网大厂Java面试:从Java SE到大数据场景的技术深度解析
java·大数据·spring boot·面试·spark·java se·互联网大厂
笨蛋不要掉眼泪10 小时前
Spring Boot集成LangChain4j:与大模型对话的极速入门
java·人工智能·后端·spring·langchain
Yvonne爱编码10 小时前
JAVA数据结构 DAY3-List接口
java·开发语言·windows·python
像少年啦飞驰点、11 小时前
零基础入门 Spring Boot:从“Hello World”到可上线微服务的完整学习指南
java·spring boot·微服务·编程入门·后端开发