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. Java 开发常用工具

    编译器 IDEA (个人觉得IDEA比较好用) Eclipse MyEclipse IDEA插件 Lombok: 使用注解,免去实体类中get /set/构造器等代码 ,需要引入lombok包 Ali ...

  2. redis bind连不上的坑

    由于需要在内网其他服务器上连接redis服务器(192.168.1.110),本想直接在redis配置文件中加上目标的IP地址: bind 192.168.1.166 就可以了,实际上不正确. red ...

  3. Python-网络爬虫模块-requests模块之请求

    Python原生库urllib库不太方便使用,本着"人生苦短, 我用Python"的珍惜生命精神, 基于urllib, 开发了一个对人类来说, 更好使用的一个库——requests ...

  4. vue-cli项目使用mock数据的方法(借助express)

    前言 现如今前后端分离开发越来越普遍,前端人员写好页面后可以自己模拟一些数据进行代码测试,这样就不必等后端接口,提高了我们开发效率.今天就来分析下前端常用的mock数据的方式是如何实现的. 主体 项目 ...

  5. 试试使用 eolinker 扫描 GitLab 代码注释自动生成 API 文档?

    前言: 一般写完代码之后,还要将各类参数注解写入API文档,方便后续进行对接和测试,这个过程通常都很麻烦,如果有工具可以读取代码注释直接生成API文档的话,那会十分方便. 此前一直都是在使用eolin ...

  6. SmartSql 快速使用指南

    SmartSql 快速使用指南(https://github.com/Ahoo-Wang/SmartSql) ISmartSqlMapper 常用(部分)接口概述 函数 说明 Execute IDbC ...

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

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

  8. Docker部署Zabbix监控MariaDB主从同步(Percona Monitoring Plugins for Zabbix)

    一.安装Docker并部署Zabbix 建议先配置清华大学的docker-ce yum源,速度有保障:清华大学repo源 1.Zabbix Server节点配置 部署环境: [root@server0 ...

  9. DSAPI 短域名服务

    有时,需要将长域名转换为短域名,或是为了减少字符量,或是为了隐藏真实网址.在DSAPI中,集成了EPS-GS的短域名接口.该功能需要联接互联网,从EPS服务器获取. 代码 DSAPI.网络.短域名服务 ...

  10. [转] 以后再有人问你selenium是什么,你就把这篇文章给他

    本文转自:https://blog.csdn.net/TestingGDR/article/details/81950593 写在最前面:目前自动化测试并不属于新鲜的事物,或者说自动化测试的各种方法论 ...