关闭

Spring Boot 上传文件(spring boot upload file)

标签: Spring Bootfile uploadspringwebThymeleaf
861人阅读 评论(0) 收藏 举报
分类:

本篇文章将说明在Spring Boot web程序中如何上传文件。

开发环境:

1. eclipse Oxygen Release (4.7.0)

2. Spring Boot 1.4.3 RELEASE

3. Spring 4.3.5 RELEASE

4. Thymelaef

5. Maven

6. Embedded Tomcat 8


1.最终的项目结构


2.项目所需依赖 pom.xml

<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>

  <groupId>org.thinkingingis</groupId>
  <artifactId>spring-boot-fileupload</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>spring-boot-fileupload</name>
  <url>http://maven.apache.org</url>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.4.3.RELEASE</version>
    </parent>

  <properties>
    <java.version>1.8</java.version>
  </properties>

  <dependencies>
  
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <optional>true</optional>
        </dependency>

  </dependencies>
  
  
  <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
  
</project>

3. UploadController.java

用MultipartFile类去匹配上传的文件

package org.thinkingingis.controller;

import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.Paths;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;

@Controller
public class UploadController {
	
	private static String UPLOAD_FOLDER = "H://temp//";
	
	@GetMapping("/")
	public String index() {
		return "upload";
	}
	
	@PostMapping("/upload")
	public String singleFileUpload(@RequestParam("file") MultipartFile file,
								   RedirectAttributes redirectAttributes) {
		if(file.isEmpty()) {
			redirectAttributes.addFlashAttribute("message", "请选择一个上传文件");
		}
		
		try {
			
			byte[] bytes = file.getBytes();
			Path path = Paths.get(UPLOAD_FOLDER + file.getOriginalFilename());
			Files.write(path, bytes);
			redirectAttributes.addFlashAttribute("message", "已经将 '" + file.getOriginalFilename() + "' 的文件上传成功");
			
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		
		return "redirect:/uploadStatus";
	}
	
	@GetMapping("/uploadStatus")
	public String uploadStatus() {
		return "uploadStatus";
	}
	
}

4. Thymeleaf 前端页面

4.1 upload.html

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">

<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />  
</head>

<body>

<h1>ThinkingInGIS</h1> <br/>

<h1>Spring Boot 文件上传示例</h1>

<form method="POST" action="/upload" enctype="multipart/form-data">
    <input type="file" name="file" /><br/><br/>
    <input type="submit" value="上传" />
</form>

</body>
</html>
4.2  uploadStatus.html

<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">

<head>
	<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />  
</head>

<body>

<h1>Spring Boot - 上传状态</h1>

<div th:if="${message}">
    <h2 th:text="${message}"></h2>
</div>

</body>
</html>
5. 处理文件过大的情况

下面 GlobalExceptionHandler.java 这个类是处理当上传文件超过10mb限制所引发的异常情况。

package org.thinkingingis.controller;

import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.multipart.MultipartException;
import org.springframework.web.servlet.mvc.support.RedirectAttributes;

@ControllerAdvice
public class GlobalExceptionHandler {
	
	public String handerError(MultipartException e, RedirectAttributes redirectAttributes) {
		redirectAttributes.addFlashAttribute("message", e.getCause().getMessage());
		return "redirect:/uploadStatus";
	}

}

6. Tomcat大文件重置连接

对于embedded tomcat ,需要声明TomcatEmbeddedServletContainerFactory

package org.thinkingingis.controller;

import org.apache.coyote.http11.AbstractHttp11Protocol;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.context.embedded.tomcat.TomcatConnectorCustomizer;
import org.springframework.boot.context.embedded.tomcat.TomcatEmbeddedServletContainerFactory;
import org.springframework.context.annotation.Bean;

@SpringBootApplication
public class SpringBootWebApplication {
	
	//private int maxUploadFileSize = 10 * 1024 * 1024;
	
	public static void main(String[] args) throws Exception {
		SpringApplication.run(SpringBootWebApplication.class, args);
	}

	
    //Tomcat large file upload connection reset
    @Bean
    public TomcatEmbeddedServletContainerFactory tomcatEmbedded() {

        TomcatEmbeddedServletContainerFactory tomcat = new TomcatEmbeddedServletContainerFactory();

        tomcat.addConnectorCustomizers((TomcatConnectorCustomizer) connector -> {
            if ((connector.getProtocolHandler() instanceof AbstractHttp11Protocol<?>)) {
                //-1 means unlimited
                ((AbstractHttp11Protocol<?>) connector.getProtocolHandler()).setMaxSwallowSize(-1);
            }
        });

        return tomcat;
    }
}


7. 在application.properties中设置上传文件的上限

#http://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#common-application-properties
#search multipart
spring.http.multipart.max-file-size=10MB
spring.http.multipart.max-request-size=10MB


8. 进入项目文件  输入mvn spring-boot:run


9. 启动成功后浏览器输入 localhost:8080


上传成功后



到此就实现了Spring Boot上传文件的功能。

如遇到问题,欢迎通过公众号留言给作者,以便共同探讨。

邮箱:thinkingingis@qq.com

微信公众号:


0
0
查看评论

解决使用Spring Boot、Multipartfile上传文件路径错误问题

彻底跟路径错误say拜拜! 题图:from Google 1.问题描述 关键字: SpringMVC 4.2.4 、 Spring Boot 1.3.1 、Servlet 3.0 、文件上传报错信息: java.io.IOException: java.io.F...
  • daniel7443
  • daniel7443
  • 2016-06-09 12:48
  • 36901

springmvc上传临时文件目录配置

bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> propert...
  • z69183787
  • z69183787
  • 2016-08-20 14:13
  • 4026

SpringBoot下文件上传与下载的实现

本文欢迎转载,转载请注明出处,谢谢~(作者:喝酒不骑马 Colton_Null) from CSDNSpringBoot后台如何实现文件上传下载?最近做的一个项目涉及到文件上传与下载。前端上传采用百度webUploader插件。有关该插件的使用方法还在研究中,日后整理再记录。本文主要介绍Sprin...
  • Colton_Null
  • Colton_Null
  • 2017-08-05 00:40
  • 2760

SpringBoot文件上传下载和多文件上传(图文详解)

最近在学习SpringBoot,以下是最近学习整理的实现文件上传下载的java代码: 1、开发环境: IDEA15+ Maven+JDK1.8 2、新建一个maven工程: 3、工程框架 4、pom.xml文件依赖项<project xmlns="http://ma...
  • Coding13
  • Coding13
  • 2017-01-16 20:16
  • 27708

SpringBoot File Upload

  • 2017-01-11 17:17
  • 43KB
  • 下载

Spring Boot 文件上传

使用SpringBoot进行文件上传的方法和SpringMVC差不多,本文单独新建一个最简单的DEMO来说明一下。 主要步骤包括: 1、创建一个springboot项目工程,本例名称(demo-uploadfile)。 2、配置 pom.xml 依赖。 3、创建和编写文件上传的 Contro...
  • catoop
  • catoop
  • 2017-03-11 13:56
  • 25781

springboot文件上传

package com.etaxserver.controller; import java.io.File; import java.io.IOException; import java.util.Iterator; import javax.annotation.Resource; imp...
  • gezh123
  • gezh123
  • 2017-02-22 16:36
  • 630

SpringBoot MultiPartFile To File 问题

之前在SpringMVC中没有碰到的问题如今在SpringBoot中成了一个问题,害我花了半天搞定。问题再现: 截取部分代码public String analyzeFile(MultipartFile file) { if(!file.isEmpty()) { ...
  • linfujian1999
  • linfujian1999
  • 2017-08-25 13:05
  • 1524

spring-boot上传文件MultiPartFile获取不到文件问题解决

spring-boot上传文件MultiPartFile获取不到文件问题解决。现象是在spring-boot里加入commons-fileupload jar并且配置了mutilPart的bean,在upload的POST请求后,发现multipartRequest.getFiles("f...
  • happy_cheng
  • happy_cheng
  • 2017-01-07 22:02
  • 14491

springboot框架下的上传下载

项目接触到新的框架技术:springboot+angularjs+bootstrap 其中稍微有点难度的就属于上传下载了 1,上传文件 前端样式如上所示,点击"导入模板文件",浏览选择文件,点击“导入”则上传文件信息到服务器,当上传成功后,在右侧显示文件名,并...
  • chenqk_123
  • chenqk_123
  • 2015-07-27 16:19
  • 13017