news 2026/4/18 6:32:05

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/17 7:31:38

用BART微调医疗病历摘要更稳

&#x1f4dd; 博客主页&#xff1a;jaxzheng的CSDN主页 医疗病历摘要的稳定性革命&#xff1a;BART微调的鲁棒性优化策略目录医疗病历摘要的稳定性革命&#xff1a;BART微调的鲁棒性优化策略 引言&#xff1a;当精度不再是唯一标尺 问题深度剖析&#xff1a;稳定性为何是医疗摘…

作者头像 李华
网站建设 2026/4/17 23:22:27

HY-MT1.5-7B模型推理优化:显存占用降低技巧

HY-MT1.5-7B模型推理优化&#xff1a;显存占用降低技巧 1. 背景与技术挑战 随着大语言模型在多语言翻译任务中的广泛应用&#xff0c;高效部署成为实际落地的关键瓶颈。腾讯开源的混元翻译大模型 HY-MT1.5 系列包含两个核心版本&#xff1a;HY-MT1.5-1.8B 和 HY-MT1.5-7B&…

作者头像 李华
网站建设 2026/4/17 22:45:37

HY-MT1.5-1.8B实时翻译延迟优化实战

HY-MT1.5-1.8B实时翻译延迟优化实战 随着多语言交流需求的不断增长&#xff0c;高质量、低延迟的实时翻译系统成为智能设备、跨语言沟通和全球化服务的核心支撑。腾讯开源的混元翻译大模型HY-MT1.5系列&#xff0c;凭借其在翻译质量与推理效率之间的出色平衡&#xff0c;迅速成…

作者头像 李华
网站建设 2026/3/26 6:48:22

混元翻译1.5模型实战:多语言视频字幕生成

混元翻译1.5模型实战&#xff1a;多语言视频字幕生成 随着全球化内容消费的快速增长&#xff0c;多语言视频字幕的自动生成已成为跨文化传播、在线教育和流媒体平台的核心需求。传统翻译方案在面对复杂语境、混合语言表达以及实时性要求时&#xff0c;往往难以兼顾质量与效率。…

作者头像 李华
网站建设 2026/4/18 5:38:37

PDF-Extract-Kit教程:PDF文档安全处理技巧

PDF-Extract-Kit教程&#xff1a;PDF文档安全处理技巧 1. 引言 1.1 技术背景与学习目标 在数字化办公和学术研究中&#xff0c;PDF 文档已成为信息传递的核心载体。然而&#xff0c;PDF 的封闭性使得内容提取&#xff08;如公式、表格、文本&#xff09;成为一大挑战。传统工…

作者头像 李华
网站建设 2026/4/18 5:31:19

腾讯开源模型部署:HY-MT1.5高可用方案设计

腾讯开源模型部署&#xff1a;HY-MT1.5高可用方案设计 1. 引言&#xff1a;腾讯开源翻译大模型的演进与挑战 随着全球化进程加速&#xff0c;高质量、低延迟的机器翻译需求日益增长。传统云中心化翻译服务虽具备强大算力支撑&#xff0c;但在隐私保护、实时响应和边缘场景适应…

作者头像 李华