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文件上传下载简单使用的更多相关文章

  1. springmvc文件上传下载简单实现案例(ssm框架使用)

    springmvc文件上传下载实现起来非常简单,此springmvc上传下载案例适合已经搭建好的ssm框架(spring+springmvc+mybatis)使用,ssm框架项目的搭建我相信你们已经搭 ...

  2. SpringBoot文件上传下载

    项目中经常会有上传和下载的需求,这篇文章简述一下springboot项目中实现简单的上传和下载. 新建springboot项目,前台页面使用的thymeleaf模板,其余的没有特别的配置,pom代码如 ...

  3. springboot文件上传下载,转载的

    Spring Boot入门——文件上传与下载 原文来自:https://www.cnblogs.com/studyDetail/articles/7003253.html 1.在pom.xml文件中添 ...

  4. springboot 文件上传下载

    关键点: 1,使用 POST 请求2,consumes=MediaType.MULTIPART_FROM_DATA_VALUE3,@RequestParm 里面的字符串和前端 input 控件的 na ...

  5. salesforce 零基础学习(四十二)简单文件上传下载

    项目中,常常需要用到文件的上传和下载,上传和下载功能实际上是对Document对象进行insert和查询操作.本篇演示简单的文件上传和下载,理论上文件上传后应该将ID作为操作表的字段存储,这里只演示文 ...

  6. SpringBoot入门一:基础知识(环境搭建、注解说明、创建对象方法、注入方式、集成jsp/Thymeleaf、logback日志、全局热部署、文件上传/下载、拦截器、自动配置原理等)

    SpringBoot设计目的是用来简化Spring应用的初始搭建以及开发过程.该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置.通过这种方式,SpringBoot致力于在蓬勃发 ...

  7. 补习系列(11)-springboot 文件上传原理

    目录 一.文件上传原理 二.springboot 文件机制 临时文件 定制配置 三.示例代码 A. 单文件上传 B. 多文件上传 C. 文件上传异常 D. Bean 配置 四.文件下载 小结 一.文件 ...

  8. SpringMVC文件上传下载(单文件、多文件)

    前言 大家好,我是bigsai,今天我们学习Springmvc的文件上传下载. 文件上传和下载是互联网web应用非常重要的组成部分,它是信息交互传输的重要渠道之一.你可能经常在网页上传下载文件,你可能 ...

  9. commons-fileupload实现文件上传下载

    commons-fileupload是Apache提供的一个实现文件上传下载的简单,有效途径,需要commons-io包的支持,本文是一个简单的示例 上传页面,注意设置响应头 <body> ...

随机推荐

  1. 【TensorFlow篇】--Tensorflow框架实现SoftMax模型识别手写数字集

    一.前述 本文讲述用Tensorflow框架实现SoftMax模型识别手写数字集,来实现多分类. 同时对模型的保存和恢复做下示例. 二.具体原理 代码一:实现代码 #!/usr/bin/python ...

  2. Vue.js-03:第三章 - 事件修饰符的使用

    一.前言 熟悉了 Vue 的指令系统后,在实际开发中,不可避免的会使用到对于事件的操作,如何处理 DOM 事件流,成为我们必须要掌握的技能.不同于传统的前端开发,在 Vue 中给我们提供了事件修饰符这 ...

  3. .NET Core微服务之基于Ocelot实现API网关服务

    Tip: 此篇已加入.NET Core微服务基础系列文章索引 一.啥是API网关? API 网关一般放到微服务的最前端,并且要让API 网关变成由应用所发起的每个请求的入口.这样就可以明显的简化客户端 ...

  4. 【Android Studio安装部署系列】三十六、从Android Studio3.1.4升级到Android studio3.2【以及创建android p模拟器(未成功)】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 概述 因为想要使用Android P模拟器,所以需要将Android Studio升级到3.2版本以上. 按照官网的说法:参考<ht ...

  5. SpringSecurity自定义AuthenticationProvider和AuthenticationFilter

    AuthenticationProvider 默认实现:DaoAuthenticationProvider 授权方式提供者,判断授权有效性,用户有效性,在判断用户是否有效性,它依赖于UserDetai ...

  6. DotNetCore跨平台~EFCore数据上下文的创建方式

    回到目录 对于DotNetCore来说,把大部分组件者放在DI容器里,在startup中进行注入,在类的构造方法中进行使用,如果某些情况下,无法使用这种DI的方式,也可以自己控制数据上下文的生产过程, ...

  7. Linux用户和权限管理看了你就会用啦

    前言 只有光头才能变强 回顾前面: 看完这篇Linux基本的操作就会了 没想到上一篇能在知乎获得千赞呀,Linux也快期末考试了,也有半个月没有写文章了.这篇主要将Linux下的用户和权限知识点再整理 ...

  8. Windows系统pip安装whl包

    1.确保PIP的存在 2.CMD命令进入C:\Python34\Scripts里面后再执行PIP命令安装pip install wheel     # D:   和cd  地址 3.把文件最好放在\S ...

  9. 并发系列(2)之 ThreadLocal 详解

    本文将主要结合源码讲述 ThreadLocal 的使用场景和内部结构,以及 ThreadLocalMap 的内部结构:另外在阅读文本之前只好先了解一下引用和 HashMap 的相关知识,可以参考 Re ...

  10. 浅谈Linux基本命令

    本篇文章作为Linux 入门的必备篇,主要简述Linux系统目录结构和Linux 基本Shell命令,大致内容如下: ​ 一  Linux目录及其概述 如下目录为CentOS 7目录结构 ​ 1.建立 ...