news 2026/4/13 13:35:31

Spring Boot文件上传

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Spring Boot文件上传
5.3.1文件上传

开发Web应用时,文件上传是很常见的一个需求浏览器通过表单形式将文件以流的形式传递给服务器,服务器再对上传的数据解析处理。下面我们通过一个案例讲解如何使用SpringBoot实现文件上传,具体步骤如下。

1.编写文件上传的表单页面

在chapter05项目根路径下的templates 模板引擎文件夹下创建一个用来上传文件的upload.html模板页面,内容如下列代码所示。

<!DOCTYPE html> <html lang="en"xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <meta http-equiv="Content-Type" content=“text/html; charset=UTF-8”> <title>动态添加文件上传列表</title> <link th:href="@{/login/css/bootstrap.min.css}" rel="stylesheet"> <script th:src="@{/login/js/jquery.min.js}"></script> </head> <body> <div th:if="${uploadStatus}" style="color: red" th:text="${uploadStatus}"> 上传成功</div> <form th:action="@{/uploadFile}"method="post" enctype="multipart/form-data"> 上传文件:&nbsp;&nbsp;<input type="button"value="添加文件"onclick="add()"/> <div id-"file" style="margin-top:10px;"th:value="文件上传区域"> </div> <input id="submit" type="submit" value="上传" style="display: none;margin-top: 10px;"/> </form> <script type="text/javascript"> //动态添加上传按钮 function add(){ var innerdiv = "<div>"; innerdiv += "<input type='file' name='fileUpload' required='required'>"+ "<input type='button' value-'删除’ onclick='remove(this)'>"; innerdiv +="</div>"; $("#file").append(innerdiv); //打开上传按钮 $("#submit").css("display","block"); } //删除当前行<div> function remove (obj) { $(obj).parent().remove(); if($("#file div").length ==0){ $("#submit").css("display","none"); } } </script> </body> </html>

在上述代码中,第1318行代码的<form>标签用于创建上传文件的表单。第1937行是一段JavaScript脚本代码,用来处理用户动态添加或者移除上传输入框。
另外在文件5-11中第8行代码还引入了静态资源目录下的login/js中的jquery.min.js文件,因此,这里需要在项目resources/static/login 目录下创建一个 js 文件夹,并引入jquery.min.js文件。

2.在全局配置文件中添加文件上传的相关配置

在全局配置文件 application.properties 中添加文件上传的相关设置,内容如下列代码所示。

# thymeleaf 页面缓存设置(默认为true),开发中为方便调试应设置为false,上线稳定后应保持默认true spring.thymeleaf.cache=false # 配置国际化文件基础名 spring.messages.basename=i18n.login # 单个上传文件大小限制(默认为1MB) spring.servlet.multipart.max-file-size=10MB # 总上传文件大小限制(默认为10MB) spring.servlet.multipart.max-request-size=50MB

在上述代码中,在项目全局配置文application.properties已有配置的基础上,对文件上传过程中的上传大小进行了设置。其中,spring.servlet.multipart.max-file-size用来设置单个上传文件的大小限制,默认值为1MB,上述文件设置为10MB;spring.servlet.multipart.maxrequest-size 用来设置所有上传文件的大小限制,默认值为10MB,这里设置为50MB。如果上传文件的大小超出限制,会提示“FileUploadBaseyFileSizeLimitExceededException:The field fleUpload exceeds its maximum permitted size of 1048576 bytes"异常信息,因此开发者需要结合实际需求合理设置文件大小。

3.进行文件上传处理,实现文件上传功能

在之前创建的com.itheima.controller 包下创建一个管理文件上传下载的控制类FileController,用于实现文件上传功能,内容如下列代码所示。

import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import java.io.File; import java.util.UUID; /** *文件管理控制类 */ @Controller public class FileController // 向文件上传页面跳转 @GetMapping("/toupload") public String toupload(){ return "upload"; } //文件上传管理 @PostMapping("/uploadFile") public String uploadFile (MultipartFile[] fileupload, Model model){ //默认文件上传成功,并返回状态信息 model.addattribute("uploadStatus",“上传成功!"); for (MultipartFile file : fileUpload) { // 获取文件名以及后级名 String fileName = file.getOriginalFilename(); // 重新生成文件名(根据具体情况生成对应文件名) fileName = UUID.randomUUID()+""+fileName; // 指定上传文件本地存储目录,不存在则需要提前创建 String dirPath = "F:/file/"; File filePath = new File(dirPath); if(!filePath.exists()){ filePath.mkdirs(); } try { file.transferTo(new File(dirPath+fileName)) } catch (Exception e) { e.printStackTrace(); //上传失败,返回失败信息 model.addAttribute("uploadstatus",,"上传失败:"+e.getMessage()); } } //携带上传状态信息回调到文件上传贞面 return "upload"; } }

文件5-13中,toUpload()方法用于处理路径为“/toUpload”的GET请求,并返回上传页面的路径。uploadFile()方法用于处理路径为“/uploadFile”的POST请求,如果文件上传成功,则会将上传的文件重命名并存储在“F:/ile/”目录。如果上传失败,则会提示上传失败的相关信息。需要注意的是,uploadFile()方法的参数fileUpload 的名称必须与上传页面中的name 值一致。

4.效果测试

启动项目,项目启动成功后,在浏览器上访问“http:/localhost-8080/oUpload",效果如图5-18所示。
单击图5-13所示窗口中的【添加文件】按钮,能够动态添加多个文件,效果如图5-14所示。


在图5-14所示的文件上传页面中,共添加了3个上传的文件,每个上传文件后方对应一个【删除】按钮,用于移除上传的文件。单击文件上传页面的【上传】按钮,如果存在未选择的文件,会提示“请选择一个文件”,否则选择好的上传文件会进行上传处理,效果如图5-15所示。
从图5-15可以看出,文件上传成功后页面会提示“上传成功”。为了验证文件上传效果,打开上传文件的存储目录“F:/ile/”,效果如图5-16所示。


从图5-16可以看出,在定制的上传文件存储目录“F:/ile/”下,出现了选择上传的3个不同类型的文件,同时文件名也根据设置进行了相应的修改,读者还可以打开每个文件查看具体的文件内容。

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

Spring Boot整合Redisson的两种方式

项目场景 Spring Boot整合Redisson的两种方式&#xff0c;方式一直接使用yml配置&#xff0c;方式二创建RedissonConfig配置类。前言redisson和redis区别&#xff1a; Redis是一个开源的内存数据库&#xff0c;支持多种数据类型&#xff0c;如字符串、哈希、列表、集合和有序集…

作者头像 李华
网站建设 2026/4/10 6:09:54

HY-MT1.5-1.8B性能调优:边缘计算场景适配

HY-MT1.5-1.8B性能调优&#xff1a;边缘计算场景适配 1. 引言&#xff1a;轻量级大模型在边缘翻译中的价值 随着多语言交流需求的爆发式增长&#xff0c;高质量、低延迟的实时翻译能力正成为智能设备、移动应用和边缘计算系统的核心诉求。传统云端翻译服务虽具备强大算力支撑…

作者头像 李华
网站建设 2026/4/11 15:16:28

LCD Image Converter入门必看:超详细版使用说明

从像素到代码&#xff1a;如何用 LCD Image Converter 高效打通嵌入式图形开发链路你有没有遇到过这样的场景&#xff1f;UI设计师甩来一个精美的PNG图标&#xff0c;你满怀信心地打开Keil&#xff0c;想把它“贴”到OLED屏幕上——结果发现&#xff0c;MCU根本不认识PNG。手动…

作者头像 李华
网站建设 2026/4/6 0:47:01

从模型到产品:基于HY-MT1.5的翻译APP开发

从模型到产品&#xff1a;基于HY-MT1.5的翻译APP开发 随着多语言交流需求的不断增长&#xff0c;高质量、低延迟的翻译服务已成为智能应用的核心能力之一。腾讯开源的混元翻译大模型 HY-MT1.5 系列&#xff0c;凭借其在多语言支持、边缘部署能力和上下文理解方面的突出表现&am…

作者头像 李华
网站建设 2026/4/7 17:33:05

HY-MT1.5模型测试:压力与负载测试

HY-MT1.5模型测试&#xff1a;压力与负载测试 1. 引言 随着全球化进程的加速&#xff0c;高质量、低延迟的机器翻译需求日益增长。腾讯近期开源了其新一代混元翻译大模型系列——HY-MT1.5&#xff0c;包含两个核心版本&#xff1a;HY-MT1.5-1.8B 和 HY-MT1.5-7B&#xff0c;分…

作者头像 李华
网站建设 2026/4/8 10:50:54

Qwen2.5-1M:100万token上下文AI处理新标杆!

Qwen2.5-1M&#xff1a;100万token上下文AI处理新标杆&#xff01; 【免费下载链接】Qwen2.5-14B-Instruct-1M 项目地址: https://ai.gitcode.com/hf_mirrors/Qwen/Qwen2.5-14B-Instruct-1M 导语&#xff1a;阿里云推出Qwen2.5系列的长上下文版本Qwen2.5-14B-Instruct-…

作者头像 李华