您好,欢迎访问一九零五行业门户网

SpringBoot如何实现文件上传与下载功能

spring boot文件上传与下载在实际的web应用开发中,为了成功上传文件,必须将表单的method设置为post,并将enctype设置为multipart/form-data。只有这种设置,浏览器才能将所选文件的二进制数据发送给服务器。
从servlet 3.0开始,就提供了处理文件上传的方法,但这种文件上传需要在java servlet中完成,而spring mvc提供了更简单的封装。spring mvc是通过apache commons fileupload技术实现一个multipartresolver的实现类commonsmultipartresolver完成文件上传的。因此,spring mvc的文件上传需要依赖apache commons fileupload组件。
spring mvc将上传文件自动绑定到multipartfile对象中,multipartfile提供了获取上传文件内容、文件名等方法,并通过transferto方法将文件上传到服务器的磁盘中,multipartfile的常用方法如下:
byte[] getbytes():获取文件数据。
string getcontenttype():获取文件mime类型,如image/jpeg等。
inputstream getinputstream():获取文件流。
string getname():获取表单中文件组件的名字。
string getoriginalfilename():获取上传文件的原名。
long getsize():获取文件的字节大小,单位为byte。
boolean isempty():是否有(选择)上传文件。
void transferto(file dest):将上传文件保存到一个目标文件中。
spring boot的spring-boot-starter-web已经集成了spring mvc,所以使用spring boot实现文件上传,更加便捷,只需要引入apache commons fileupload组件依赖即可。
举例说明下面通过一个实例讲解spring boot文件上传与下载的实现过程。
【例7】spring boot文件上传与下载。
具体实现步骤如下。
1.引入apache commons fileupload组件依赖在web应用ch7_2的pom.xml文件中,添加apache commons fileupload组件依赖,具体代码如下:
<dependency> <groupid>commons-fileupload</groupid> <artifactid>commons-fileupload</artifactid> <!-- 由于commons-fileupload组件不属于spring boot,所以需要加上版本 --> <version>1.4</version></dependency>
2.设置上传文件大小限制在web应用ch7_2的配置文件application.properties中,添加如下配置进行限制上传文件大小。
#上传文件时,默认单个上传文件大小是1mb,max-file-size设置单个上传文件大小spring.servlet.multipart.max-file-size=50mb#默认总文件大小是10mb,max-request-size设置总上传文件大小spring.servlet.multipart.max-request-size=500mb
3.创建选择文件视图页面在ch7_2应用的src/main/resources/templates目录下,创建选择文件视图页面uploadfile.html。该页面中有个enctype属性值为multipart/form-data的form表单,具体代码如下:
<!doctype html><html xmlns:th="http://www.thymeleaf.org"><head><meta charset="utf-8"><title>insert title here</title><link rel="stylesheet" th:href="@{css/bootstrap.min.css}" /><!-- 默认访问 src/main/resources/static下的css文件夹--><link rel="stylesheet" th:href="@{css/bootstrap-theme.min.css}" /></head><body><div class="panel panel-primary"> <div class="panel-heading"> <h4 class="panel-title">文件上传示例</h4> </div> </div> <div class="container"> <div class="row"> <div class="col-md-6 col-sm-6"> <form class="form-horizontal" action="upload" method="post" enctype="multipart/form-data"> <div class="form-group"> <div class="input-group col-md-6"> <span class="input-group-addon"> <i class="glyphicon glyphicon-pencil"></i> </span> <input class="form-control" type="text" name="description" th:placeholder="文件描述"/> </div> </div> <div class="form-group"> <div class="input-group col-md-6"> <span class="input-group-addon"> <i class="glyphicon glyphicon-search"></i> </span> <input class="form-control" type="file" name="myfile" th:placeholder="请选择文件"/> </div> </div> <div class="form-group"> <div class="col-md-6"> <div class="btn-group btn-group-justified"> <div class="btn-group"> <button type="submit" class="btn btn-success"> <span class="glyphicon glyphicon-share"></span> 上传文件 </button> </div> </div> </div> </div> </form> </div> </div> </div></body></html>
4.创建控制器在ch7_2应用的com.ch.ch7_2.controller包中,创建控制器类testfileupload。在该类中有4个处理方法,一个是界面导航方法uploadfile,一个是实现文件上传的upload方法,一个是显示将要被下载文件的showdownload方法,一个是实现下载功能的download方法。核心代码如下:
@controllerpublic class testfileupload { @requestmapping("/uploadfile") public string uploadfile() { return "uploadfile"; } /** * 上传文件自动绑定到multipartfile对象中, * 在这里使用处理方法的形参接收请求参数。 */ @requestmapping("/upload") public string upload( httpservletrequest request, @requestparam("description") string description, @requestparam("myfile") multipartfile myfile)throws illegalstateexception, ioexception { system.out.println("文件描述:" + description); //如果选择了上传文件,将文件上传到指定的目录uploadfiles if(!myfile.isempty()) { //上传文件路径 string path = request.getservletcontext().getrealpath("/uploadfiles/"); //获得上传文件原名 string filename = myfile.getoriginalfilename(); file filepath = new file(path + file.separator + filename); //如果文件目录不存在,创建目录 if(!filepath.getparentfile().exists()) { filepath.getparentfile().mkdirs(); } //将上传文件保存到一个目标文件中 myfile.transferto(filepath); } //转发到一个请求处理方法,查询将要下载的文件 return "forward:/showdownload"; } /** * 显示要下载的文件 */ @requestmapping("/showdownload") public string showdownload(httpservletrequest request, model model) { string path = request.getservletcontext().getrealpath("/uploadfiles/"); file filedir = new file(path); //从指定目录获得文件列表 file fileslist[] = filedir.listfiles(); model.addattribute("fileslist", fileslist); return "showfile"; } /** * 实现下载功能 */ @requestmapping("/download") public responseentity<byte[]> download( httpservletrequest request, @requestparam("filename") string filename, @requestheader("user-agent") string useragent) throws ioexception { //下载文件路径 string path = request.getservletcontext().getrealpath("/uploadfiles/"); //构建将要下载的文件对象 file downfile = new file(path + file.separator + filename); //ok表示http中的状态是200 bodybuilder builder = responseentity.ok(); //内容长度 builder.contentlength(downfile.length()); //application/octet-stream:二进制流数据(最常见的文件下载) builder.contenttype(mediatype.application_octet_stream); //使用urlencoder.encode对文件名进行编码 filename = urlencoder.encode(filename,"utf-8"); /** * 设置实际的响应文件名,告诉浏览器文件要用于“下载”和“保存”。 * 不同的浏览器,处理方式不同,根据浏览器的实际情况区别对待。 */ if(useragent.indexof("msie") > 0) { //ie浏览器,只需要用utf-8字符集进行url编码 builder.header("content-disposition", "attachment; filename=" + filename); }else { /**非ie浏览器,如firefox、chrome等浏览器,则需要说明编码的字符集 * filename后面有个*号,在utf-8后面有两个单引号 */ builder.header("content-disposition", "attachment; filename*=utf-8''" + filename); } return builder.body(fileutils.readfiletobytearray(downfile)); }}
5.创建文件下载视图页面在ch7_2应用的src/main/resources/templates目录下,创建文件下载视图页面showfile.html。核心代码如下:
<body> <div class="panel panel-primary"> <div class="panel-heading"> <h4 class="panel-title">文件下载示例</h4> </div> </div> <div class="container"> <div class="panel panel-primary"> <div class="panel-heading"> <h4 class="panel-title">文件列表</h4> </div> <div class="panel-body"> <div class="table table-responsive"> <table class="table table-bordered table-hover"> <tbody class="text-center"> <tr th:each="file,filestat:${fileslist}"> <td> <span th:text="${filestat.count}"></span> </td> <td> <!--file.name相当于调用getname()方法获得文件名称 --> <a th:href="@{download(filename=${file.name})}"> <span th:text="${file.name}"></span> </a> </td> </tr> </tbody> </table> </div> </div> </div> </div></body>
6.运行首先,运行ch72application主类。然后,访问http://localhost:8080/ch7_2/uploadfile测试文件上传与下载。
以上就是springboot如何实现文件上传与下载功能的详细内容。
其它类似信息

推荐信息