springboot文件上传下载简单使用
springboot的文件上传比较简单
一、使用默认的Resolver:StandardServletMultipartResolver
controller
package com.mydemo.webdemo.controller; import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.List; import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.servlet.ModelAndView; @Controller
@RequestMapping("/")
public class FileUploadController { private Logger logger = LoggerFactory.getLogger(FileUploadController.class);
@Value("${upload.file.savepath:/tmp}")
private String savePath; @RequestMapping("/toupload")
public ModelAndView toWelcome() {
ModelAndView mav = new ModelAndView();
mav.setViewName("fileupload");
mav.addObject("time", new Date());
return mav;
} /**
* 使用model传值
*
* @param uploadFile
* @param model
* @return
*/
@PostMapping("/uploadone")
public String uploadSingleFile(@RequestParam("uploadFile") MultipartFile uploadFile, Model model) {
List<MultipartFile> uploadFileList = new ArrayList<>();
logger.info(uploadFile.toString());
try {
uploadFileList.add(uploadFile);
String result = saveFile(uploadFileList);
model.addAttribute("msg", result);
} catch (Exception e) {
model.addAttribute("msg", "Upload failed");
e.printStackTrace();
}
return "uploadResult";
} /**
* 使用ModelAndView页面跳转和传值
*
* @param uploadFile
* @return
*/
@PostMapping("/uploadmore")
public ModelAndView uploadMoreFile(@RequestParam("uploadFile") MultipartFile[] uploadFile) {
ModelAndView mav = new ModelAndView();
List<MultipartFile> uploadFileList = new ArrayList<>();
try {
uploadFileList.addAll(Arrays.asList(uploadFile));
String result = saveFile(uploadFileList);
mav.addObject("msg", result);
} catch (Exception e) {
mav.addObject("msg", "Upload failed");
e.printStackTrace();
}
mav.setViewName("uploadResult");
return mav;
} private String saveFile(List<MultipartFile> uploadFileList) {
int successNum = 0;
for (MultipartFile uploadFile : uploadFileList) {
InputStream is = null;
FileOutputStream fos = null;
try {
String fileName = uploadFile.getOriginalFilename();
is = uploadFile.getInputStream();
fos = new FileOutputStream(savePath + File.separator + fileName);
int len = 0;
byte[] b = new byte[1024];
while ((len = (is.read(b))) != -1) {
fos.write(b, 0, len);
}
successNum += 1;
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
if (is != null) {
is.close();
}
if (fos != null) {
fos.close();
}
} catch (IOException e) {
e.printStackTrace();
}
}
}
if (successNum == 0) {
return "Upload failed";
} else if (successNum == uploadFileList.size()) {
return "Upload success";
} else {
return "Partial upload success";
} }
}
src/main/resources/templates/fileupload.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
Current time:<span th:text=${time} /><br />
<h5>===========================分割线=============================</h5>
<form id = "uploadone" action="${request}" th:action="@{/uploadone}" method="post" enctype="multipart/form-data">
<input type="file" name="uploadFile" /><br />
<input type="submit" value="UploadOne">
</form>
<h5>===========================分割线=============================</h5>
<form id = "uploadmore" action="${request}" th:action="@{/uploadmore}" method="post" enctype="multipart/form-data">
<input type="file" name="uploadFile" /><br />
<input type="file" name="uploadFile" /><br />
<input type="file" name="uploadFile" /><br />
<input type="submit" value="UploadMore">
</form>
</body>
</html>
src/main/resources/templates/uploadResult.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<span th:text=${msg}/>
</body>
</html>
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.4.RELEASE</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<groupId>com.mydemo.webdemo</groupId>
<artifactId>fileuploaddemo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>fileuploaddemo</name>
<description>Demo project for Spring Boot</description> <properties>
<java.version>1.8</java.version>
</properties> <dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build> </project>
application.properties
spring.mvc.servlet.load-on-startup=1
server.servlet.context-path=/uploaddemo
upload.file.savepath=D:/upload
## per file size, 500M
spring.servlet.multipart.max-file-size=524288000
## max file size in one request, 600M
spring.servlet.multipart.max-request-size=629145600
## in memory size after write to disk, 10M
spring.servlet.multipart.file-size-threshold=10240
二、使用CommonsMultipartResolver
在第一步操作的基础上,注册multipartResolver的bean为CommonsMultipartResolver
package com.mydemo.webdemo.custombean; import org.springframework.context.annotation.Bean;
import org.springframework.stereotype.Component;
import org.springframework.web.multipart.commons.CommonsMultipartResolver; @Component
public class CustomBean {
@Bean(name = "multipartResolver")
public CommonsMultipartResolver getMultipartResolver() {
CommonsMultipartResolver resolver = new CommonsMultipartResolver();
resolver.setDefaultEncoding("UTF-8");// default ISO-8859-1
resolver.setMaxInMemorySize(10240);// default 10240 ,单位bytes
resolver.setMaxUploadSize(1024*1024*600);// default -1 ,无限制,单位bytes
resolver.setMaxUploadSizePerFile(1024*1024*500);// default -1 ,无限制,单位bytes
return resolver;
} }
pom.xml文件中需要添加commons-fileupload依赖
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.4</version>
</dependency>
application.properties配置中去掉上述包含multipart的三个参数,保留如下
spring.mvc.servlet.load-on-startup=1
server.servlet.context-path=/uploaddemo
upload.file.savepath=D:/upload
三、文件下载
在上述基础上,添加下载Controller
package com.mydemo.webdemo.controller; import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.OutputStream; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse; import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody; @Controller
public class DownloadController {
private Logger logger = LoggerFactory.getLogger(FileUploadController.class); @RequestMapping("/download")
@ResponseBody
public void download(HttpServletRequest request, HttpServletResponse response) {
String fileName = request.getParameter("fileName");
String filePah = "D:/upload" + File.separator + fileName;
// 自动判断下载文件类型
response.setContentType("multipart/form-data");
// 设置文件名称
response.setHeader("Content-Disposition", "attachment;fileName=" + fileName);
FileInputStream fis = null;
OutputStream out = null;
try {
fis = new FileInputStream(filePah);
out = response.getOutputStream();
byte[] b = new byte[1024];
int len;
while ((len = fis.read(b)) != -1) {
out.write(b, 0, len);
}
} catch (IOException e) {
logger.error("", e);
} finally {
try {
if (fis != null) {
fis.close();
}
if (out != null) {
out.close();
}
} catch (IOException e) {
logger.error("", e);
}
}
}
}
D:\upload\upload.tar文件存在,则可通过如下链接下载该文件
http://localhost:8080/uploaddemo/download?fileName=upload.tar
遗留问题:
1、当上传文件大小超过了文件限制大小后,不能将异常信息传递给前端,比如本例中单个文件大小设置为500M,上传大于500M的单个文件,出现异常,但不能将该异常信息传递给前端正常显示
springboot文件上传下载简单使用的更多相关文章
- springmvc文件上传下载简单实现案例(ssm框架使用)
springmvc文件上传下载实现起来非常简单,此springmvc上传下载案例适合已经搭建好的ssm框架(spring+springmvc+mybatis)使用,ssm框架项目的搭建我相信你们已经搭 ...
- SpringBoot文件上传下载
项目中经常会有上传和下载的需求,这篇文章简述一下springboot项目中实现简单的上传和下载. 新建springboot项目,前台页面使用的thymeleaf模板,其余的没有特别的配置,pom代码如 ...
- springboot文件上传下载,转载的
Spring Boot入门——文件上传与下载 原文来自:https://www.cnblogs.com/studyDetail/articles/7003253.html 1.在pom.xml文件中添 ...
- springboot 文件上传下载
关键点: 1,使用 POST 请求2,consumes=MediaType.MULTIPART_FROM_DATA_VALUE3,@RequestParm 里面的字符串和前端 input 控件的 na ...
- salesforce 零基础学习(四十二)简单文件上传下载
项目中,常常需要用到文件的上传和下载,上传和下载功能实际上是对Document对象进行insert和查询操作.本篇演示简单的文件上传和下载,理论上文件上传后应该将ID作为操作表的字段存储,这里只演示文 ...
- SpringBoot入门一:基础知识(环境搭建、注解说明、创建对象方法、注入方式、集成jsp/Thymeleaf、logback日志、全局热部署、文件上传/下载、拦截器、自动配置原理等)
SpringBoot设计目的是用来简化Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.通过这种方式,SpringBoot致力于在蓬勃发 ...
- 补习系列(11)-springboot 文件上传原理
目录 一.文件上传原理 二.springboot 文件机制 临时文件 定制配置 三.示例代码 A. 单文件上传 B. 多文件上传 C. 文件上传异常 D. Bean 配置 四.文件下载 小结 一.文件 ...
- SpringMVC文件上传下载(单文件、多文件)
前言 大家好,我是bigsai,今天我们学习Springmvc的文件上传下载. 文件上传和下载是互联网web应用非常重要的组成部分,它是信息交互传输的重要渠道之一.你可能经常在网页上传下载文件,你可能 ...
- commons-fileupload实现文件上传下载
commons-fileupload是Apache提供的一个实现文件上传下载的简单,有效途径,需要commons-io包的支持,本文是一个简单的示例 上传页面,注意设置响应头 <body> ...
随机推荐
- 【TensorFlow篇】--Tensorflow框架实现SoftMax模型识别手写数字集
一.前述 本文讲述用Tensorflow框架实现SoftMax模型识别手写数字集,来实现多分类. 同时对模型的保存和恢复做下示例. 二.具体原理 代码一:实现代码 #!/usr/bin/python ...
- Vue.js-03:第三章 - 事件修饰符的使用
一.前言 熟悉了 Vue 的指令系统后,在实际开发中,不可避免的会使用到对于事件的操作,如何处理 DOM 事件流,成为我们必须要掌握的技能.不同于传统的前端开发,在 Vue 中给我们提供了事件修饰符这 ...
- .NET Core微服务之基于Ocelot实现API网关服务
Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.啥是API网关? API 网关一般放到微服务的最前端,并且要让API 网关变成由应用所发起的每个请求的入口.这样就可以明显的简化客户端 ...
- 【Android Studio安装部署系列】三十六、从Android Studio3.1.4升级到Android studio3.2【以及创建android p模拟器(未成功)】
版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 因为想要使用Android P模拟器,所以需要将Android Studio升级到3.2版本以上. 按照官网的说法:参考<ht ...
- SpringSecurity自定义AuthenticationProvider和AuthenticationFilter
AuthenticationProvider 默认实现:DaoAuthenticationProvider 授权方式提供者,判断授权有效性,用户有效性,在判断用户是否有效性,它依赖于UserDetai ...
- DotNetCore跨平台~EFCore数据上下文的创建方式
回到目录 对于DotNetCore来说,把大部分组件者放在DI容器里,在startup中进行注入,在类的构造方法中进行使用,如果某些情况下,无法使用这种DI的方式,也可以自己控制数据上下文的生产过程, ...
- Linux用户和权限管理看了你就会用啦
前言 只有光头才能变强 回顾前面: 看完这篇Linux基本的操作就会了 没想到上一篇能在知乎获得千赞呀,Linux也快期末考试了,也有半个月没有写文章了.这篇主要将Linux下的用户和权限知识点再整理 ...
- Windows系统pip安装whl包
1.确保PIP的存在 2.CMD命令进入C:\Python34\Scripts里面后再执行PIP命令安装pip install wheel # D: 和cd 地址 3.把文件最好放在\S ...
- 并发系列(2)之 ThreadLocal 详解
本文将主要结合源码讲述 ThreadLocal 的使用场景和内部结构,以及 ThreadLocalMap 的内部结构:另外在阅读文本之前只好先了解一下引用和 HashMap 的相关知识,可以参考 Re ...
- 浅谈Linux基本命令
本篇文章作为Linux 入门的必备篇,主要简述Linux系统目录结构和Linux 基本Shell命令,大致内容如下: 一 Linux目录及其概述 如下目录为CentOS 7目录结构 1.建立 ...