如何在Spring MVC中实现图片的上传和下载功能

简介: 如何在Spring MVC中实现图片的上传和下载功能

Spring MVC 是一个用于构建基于Java的Web应用的框架,它提供了一个易于使用的开发环境来创建复杂的Web应用。本文将详细介绍如何在Spring MVC中实现图片的上传和下载功能。

 

一、环境准备

 

1. **创建Spring MVC项目**:

   - 使用Spring Initializr生成一个基础的Spring Boot项目,选择`Web`依赖项。

   - 添加Maven依赖:

 

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

 

2. **配置文件**:

   - 在`application.properties`文件中添加以下配置:

 

```properties
      spring.servlet.multipart.enabled=true
      spring.servlet.multipart.max-file-size=2MB
      spring.servlet.multipart.max-request-size=2MB
      ```

 

二、图片上传功能

 

1. **创建上传表单**:

   - 在`src/main/resources/templates`目录下创建`upload.html`文件,内容如下:

 

```html
      <!DOCTYPE html>
      <html xmlns:th="http://www.thymeleaf.org">
      <head>
          <title>Upload Image</title>
      </head>
      <body>
          <h1>Upload Image</h1>
          <form method="POST" enctype="multipart/form-data" th:action="@{/upload}">
              <input type="file" name="file" accept="image/*"/>
              <button type="submit">Upload</button>
          </form>
      </body>
      </html>
      ```

 

2. **创建Controller**:

   - 在`src/main/java/com/example/demo/controller`目录下创建`UploadController.java`文件,内容如下:

```java
      package com.example.demo.controller;
 
      import org.springframework.stereotype.Controller;
      import org.springframework.ui.Model;
      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 java.io.File;
      import java.io.IOException;
      import java.nio.file.Path;
      import java.nio.file.Paths;
 
      @Controller
      public class UploadController {
 
          private static final String UPLOAD_DIR = "uploads/";
 
          @GetMapping("/upload")
          public String uploadForm() {
              return "upload";
          }
 
          @PostMapping("/upload")
          public String uploadFile(@RequestParam("file") MultipartFile file, Model model) {
              if (file.isEmpty()) {
                  model.addAttribute("message", "Please select a file to upload.");
                  return "upload";
              }
 
              try {
                  // 获取文件名
                  String fileName = file.getOriginalFilename();
                  // 设置保存路径
                  Path path = Paths.get(UPLOAD_DIR + fileName);
                  // 保存文件到服务器
                  file.transferTo(path.toFile());
 
                  model.addAttribute("message", "File uploaded successfully: " + fileName);
              } catch (IOException e) {
                  model.addAttribute("message", "Failed to upload file: " + e.getMessage());
              }
 
              return "upload";
          }
      }
      ```

 

3. **创建保存目录**:

   - 在项目根目录下创建一个`uploads`文件夹,用于存放上传的图片。

 

三、图片下载功能

 

1. **创建下载表单**:

   - 在`src/main/resources/templates`目录下创建`download.html`文件,内容如下:

```html
      <!DOCTYPE html>
      <html xmlns:th="http://www.thymeleaf.org">
      <head>
          <title>Download Image</title>
      </head>
      <body>
          <h1>Download Image</h1>
          <form method="GET" th:action="@{/download}">
              <input type="text" name="filename" placeholder="Enter filename"/>
              <button type="submit">Download</button>
          </form>
      </body>
      </html>
      ```

 

2. **更新Controller**:

   - 在`UploadController.java`文件中添加下载功能的代码:

```java
      import org.springframework.core.io.FileSystemResource;
      import org.springframework.core.io.Resource;
      import org.springframework.http.HttpHeaders;
      import org.springframework.http.ResponseEntity;
      import org.springframework.web.bind.annotation.RequestParam;
 
      @GetMapping("/download")
      public ResponseEntity<Resource> downloadFile(@RequestParam("filename") String filename) {
          File file = new File(UPLOAD_DIR + filename);
          if (!file.exists()) {
              return ResponseEntity.notFound().build();
          }
 
          Resource resource = new FileSystemResource(file);
          return ResponseEntity.ok()
              .header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + file.getName() + "\"")
              .body(resource);
      }
      ```

 

四、测试功能

 

1. **启动项目**:

   - 运行Spring Boot项目,启动Web服务器。

 

2. **上传图片**:

   - 在浏览器中访问`http://localhost:8080/upload`,选择图片文件并点击上传按钮。

 

3. **下载图片**:

   - 在浏览器中访问`http://localhost:8080/download`,输入上传的文件名并点击下载按钮。

 

通过以上步骤,我们成功实现了Spring MVC中图片的上传和下载功能。

 

 

五、完善上传和下载功能

 

1. **改进上传功能**:

 

  - 在上传时,避免文件名冲突,可以添加时间戳或UUID。

  - 对上传文件进行类型检查,只允许图片格式。

 

  修改后的`UploadController.java`如下:

```java
   import org.springframework.util.StringUtils;
 
   @PostMapping("/upload")
   public String uploadFile(@RequestParam("file") MultipartFile file, Model model) {
       if (file.isEmpty()) {
           model.addAttribute("message", "Please select a file to upload.");
           return "upload";
       }
 
       try {
           // 获取文件名,并添加时间戳避免冲突
           String originalFileName = StringUtils.cleanPath(file.getOriginalFilename());
           String fileName = System.currentTimeMillis() + "_" + originalFileName;
 
           // 检查文件类型
           String fileType = file.getContentType();
           if (fileType == null || !fileType.startsWith("image")) {
               model.addAttribute("message", "Only image files are allowed.");
               return "upload";
           }
 
           // 设置保存路径
           Path path = Paths.get(UPLOAD_DIR + fileName);
           // 保存文件到服务器
           file.transferTo(path.toFile());
 
           model.addAttribute("message", "File uploaded successfully: " + fileName);
       } catch (IOException e) {
           model.addAttribute("message", "Failed to upload file: " + e.getMessage());
       }
 
       return "upload";
   }
   ```

 

2. **改进下载功能**:

 

  - 提供下载文件列表,避免手动输入文件名。

  - 增加文件不存在时的友好提示。

 

  修改后的`UploadController.java`如下:

 

```java
   import java.util.stream.Collectors;
   import java.util.stream.Stream;
 
   @GetMapping("/download")
   public String downloadForm(Model model) {
       File folder = new File(UPLOAD_DIR);
       String[] files = folder.list();
       if (files != null) {
           model.addAttribute("files", Stream.of(files).collect(Collectors.toList()));
       } else {
           model.addAttribute("files", new ArrayList<>());
       }
       return "download";
   }
 
   @GetMapping("/download/{filename}")
   public ResponseEntity<Resource> downloadFile(@PathVariable("filename") String filename) {
       File file = new File(UPLOAD_DIR + filename);
       if (!file.exists()) {
           return ResponseEntity.notFound().build();
       }
 
       Resource resource = new FileSystemResource(file);
       return ResponseEntity.ok()
           .header(HttpHeaders.CONTENT_DISPOSITION, "attachment; filename=\"" + file.getName() + "\"")
           .body(resource);
   }
   ```

 

  同时修改`download.html`,如下:

 

```html
   <!DOCTYPE html>
   <html xmlns:th="http://www.thymeleaf.org">
   <head>
       <title>Download Image</title>
   </head>
   <body>
       <h1>Download Image</h1>
       <ul>
           <li th:each="file : ${files}">
               <a th:href="@{/download/{filename}(filename=${file})}" th:text="${file}">Filename</a>
           </li>
       </ul>
   </body>
   </html>
   ```

 

六、文件大小限制与异常处理

 

1. **文件大小限制**:

 

  - 配置文件大小限制,防止上传过大的文件影响服务器性能。

 

  在`application.properties`文件中添加:

```properties
   spring.servlet.multipart.max-file-size=5MB
   spring.servlet.multipart.max-request-size=5MB
   ```

 

2. **异常处理**:

 

  - 创建全局异常处理器来处理文件上传相关的异常。

 

  在`src/main/java/com/example/demo/exception`目录下创建`GlobalExceptionHandler.java`文件:

```java
   package com.example.demo.exception;
 
   import org.springframework.web.bind.annotation.ControllerAdvice;
   import org.springframework.web.bind.annotation.ExceptionHandler;
   import org.springframework.web.multipart.MaxUploadSizeExceededException;
   import org.springframework.web.servlet.mvc.support.RedirectAttributes;
 
   @ControllerAdvice
   public class GlobalExceptionHandler {
 
       @ExceptionHandler(MaxUploadSizeExceededException.class)
       public String handleMaxSizeException(MaxUploadSizeExceededException exc, RedirectAttributes redirectAttributes) {
           redirectAttributes.addFlashAttribute("message", "File too large!");
           return "redirect:/upload";
       }
   }
   ```

 

七、项目结构总结

 

项目结构如下:

```
src
├── main
│   ├── java
│   │   └── com
│   │       └── example
│   │           └── demo
│   │               ├── controller
│   │               │   └── UploadController.java
│   │               └── exception
│   │                   └── GlobalExceptionHandler.java
│   ├── resources
│   │   └── templates
│   │       ├── upload.html
│   │       └── download.html
│   └── application.properties
└── test
```

 

通过以上步骤,你已经成功实现了Spring MVC中图片的上传和下载功能,并且处理了文件大小限制和异常情况。

 

八、测试上传和下载功能

 

1. **启动项目**:

   - 运行Spring Boot项目,启动Web服务器。

 

2. **上传图片**:

   - 在浏览器中访问`http://localhost:8080/upload`,选择图片文件并点击上传按钮。

 

3. **下载图片**:

   - 在浏览器中访问`http://localhost:8080/download`,点击文件名链接下载图片。

 

 

相关文章
|
4天前
|
消息中间件 缓存 Java
手写模拟Spring Boot启动过程功能
【11月更文挑战第19天】Spring Boot自推出以来,因其简化了Spring应用的初始搭建和开发过程,迅速成为Java企业级应用开发的首选框架之一。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,帮助读者深入理解其工作机制。
21 3
|
4天前
|
Java 开发者 微服务
手写模拟Spring Boot自动配置功能
【11月更文挑战第19天】随着微服务架构的兴起,Spring Boot作为一种快速开发框架,因其简化了Spring应用的初始搭建和开发过程,受到了广大开发者的青睐。自动配置作为Spring Boot的核心特性之一,大大减少了手动配置的工作量,提高了开发效率。
20 0
|
1月前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
42 4
|
29天前
|
Java API 数据库
Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐
本文通过在线图书管理系统案例,详细介绍如何使用Spring Boot构建RESTful API。从项目基础环境搭建、实体类与数据访问层定义,到业务逻辑实现和控制器编写,逐步展示了Spring Boot的简洁配置和强大功能。最后,通过Postman测试API,并介绍了如何添加安全性和异常处理,确保API的稳定性和安全性。
35 0
|
18天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,创建并配置 Spring Boot 项目,实现后端 API;然后,使用 Ant Design Pro Vue 创建前端项目,配置动态路由和菜单。通过具体案例,展示了如何快速搭建高效、易维护的项目框架。
95 62
|
16天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
34 2
|
23天前
|
存储 Java 数据管理
强大!用 @Audited 注解增强 Spring Boot 应用,打造健壮的数据审计功能
本文深入介绍了如何在Spring Boot应用中使用`@Audited`注解和`spring-data-envers`实现数据审计功能,涵盖从添加依赖、配置实体类到查询审计数据的具体步骤,助力开发人员构建更加透明、合规的应用系统。
|
6月前
|
设计模式 前端开发 JavaScript
Spring MVC(一)【什么是Spring MVC】
Spring MVC(一)【什么是Spring MVC】
|
5月前
|
设计模式 前端开发 Java
【Spring MVC】快速学习使用Spring MVC的注解及三层架构
【Spring MVC】快速学习使用Spring MVC的注解及三层架构
75 1
|
5月前
|
前端开发 Java 应用服务中间件
Spring框架第六章(SpringMVC概括及基于JDK21与Tomcat10创建SpringMVC程序)
Spring框架第六章(SpringMVC概括及基于JDK21与Tomcat10创建SpringMVC程序)