Java:SpringMVC文件上传

SpringMVC的文件上传

1. SpringMVC框架部署

具体见Java:SpringMVC框架的部署

2. 文件上传准备工作

案例:添加图书信息、同时上传图片文件

在这里插入图片描述

2.1 创建index页面

webapp包下创建index.jsp

  • index.jsp
<%--
  Created by IntelliJ IDEA.
  User: c
  Date: 2023/1/6
  Time: 17:58
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>首页</title>
</head>
<body>
<table width="100%" height="700">
    <tr>
        <td width="200" style="border-right: red 2px solid;background-color: greenyellow">
            <ul>
                <li><a href="bookAdd.jsp" target="mainFrame">添加图书</a></li>
                <li><a href="">图书列表</a> </li>
            </ul>
        </td>
        <td>
            <iframe name="mainFrame" width="100%" height="700" frameborder="0" style="background-color: deepskyblue"></iframe>
        </td>
    </tr>
</table>
</body>
</html>

在这里插入图片描述

2.2 创建bookAdd页面

webapp包下创建bookAdd.jsp

  • bookAdd.jsp
<%--
  Created by IntelliJ IDEA.
  User: c
  Date: 2023/1/6
  Time: 20:31
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
    <h3>添加图书-表单提交</h3>
    <form action="book/add" method="post" enctype="multipart/form-data">
        <p>图书ID:<input type="text" name="bookId"/></p>
        <p>图书名称:<input type="text" name="bookName"/></p>
        <p>图书作者:<input type="text" name="bookAuthor"/></p>
        <p>图书价格:<input type="text" name="bookPrice"/></p>
        <p>图书封面:<input type="file" name="bookFile"/></p>
        <p><input type="submit" value="提交"></p>
    </form>
</body>
</html>

2.3 创建tips页面

webapp下创建tips.jsp

  • tips.jsp
<%--
  Created by IntelliJ IDEA.
  User: c
  Date: 2023/1/6
  Time: 20:31
  To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
    <h3>文件上传成功</h3>
</body>
</html>

2.4 创建Book实体类

bean包创建Book实体类:

  • 无参构造

  • 全参构造

  • setter

  • getter

  • toString

  • Book

在这里插入图片描述

2.5 创建BookController控制器

controllers包下创建建BookController

  • BookController

在这里插入图片描述

@Controller
@RequestMapping("/book")
public class BookController {
    @RequestMapping("/add")
    public String add(){
        return "/tips.jsp";
    }
}

3. 文件上传

3.1 前端提交文件

文件上传是通过表单的形式提交给服务器的,因此,实现文件的上传,就需要一个提供上传的表单,而这个表单则必须满足以下三个条件。

  • form表单的method属性为post
  • form表单的enctype属性为multipart/form-data
  • 上传文件的typefile
  • bookApp.jsp

在这里插入图片描述

    <h3>添加图书-表单提交</h3>
    <form action="book/add" method="post" enctype="multipart/form-data">
        <p>图书ID:<input type="text" name="bookId"/></p>
        <p>图书名称:<input type="text" name="bookName"/></p>
        <p>图书作者:<input type="text" name="bookAuthor"/></p>
        <p>图书价格:<input type="text" name="bookPrice"/></p>
        <p>图书封面:<input type="file" name="bookFile"/></p>
        <p><input type="submit" value="提交"></p>
    </form>

注意:使用 multiple 属性,则可以同时选择多个文件上传

enctype=multipart/form-data:该属性表明发送的请求体的内容是多表单元素的。

通俗点讲,就是有各种各样的数据,可能有二进制数据,也可能有表单数据。当使用该属性时,浏览器就会采用二进制流的方式来处理表单数据,服务器端就会对文件上传的请求进行解析处理。

3.2 控制器接收文件

SpringMVC处理上传文件需要借助于CommonsMultiparyResolver文件解析器

3.2.1 添加依赖
  • commons-io
  • commons-fileupload
<!-- /commons-io -->
<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.4</version>
</dependency>

<!--/commons-fileupload -->
<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.4</version>
</dependency>
3.2.2 配置文件解析器

spring-servlet.xml配置解析器

Spring MVC 为文件的上传提供了直接的支持,而这个支持是通过MultipartResolver对象实现。MultipartResolver是一个接口,需要他的实现类CommonsMultipartResolver来完成文件上传。而在Spring MVC中使用该对象,只需在配置文件中定义一个MultipartResolver接口的Bean即可。

注意: 配置CommonsMultipartResolver时必须指定该bean的id为multipartResolver

  • spring-servlet.xml

在这里插入图片描述

<!-- 配置文件上传解析器,将上传的文件封装为CommonsMultipartFile -->
<bean id="multipartResolver"
      class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <property name="defaultEncoding" value="UTF-8"/>
</bean>

在这里插入图片描述

3.2.3 控制器接收文件

控制器方法中用MultipartFile类型的参数接收文件数据参数名与前端提交文件的key保持一致

  • BookController

在这里插入图片描述

@Controller
@RequestMapping("/book")
public class BookController {
    @RequestMapping("/add")
    public String add(Book book, MultipartFile bookFile){
        System.out.println(book);
        System.out.println(bookFile);
        return "/tips.jsp";
    }
}
3.3 运行结果

在这里插入图片描述

4. 文件保存

将文件保存到服务器的imges目录下

4.1 控制器

1.控制器接收到前端提交的文件

2.获取文件的后缀名利用当前系统时间的毫秒值生成新的文件名

3.获取imges目录在服务器的路径

4.将文件保存到imges目录

  • bookController

在这里插入图片描述

@RequestMapping("/add")
public String add(Book book, MultipartFile bookFile, HttpServletRequest request) throws IOException {
    System.out.println("----------book.add-----------");

    //bookFile就表示上传的文件
    //1.获取上传文件的后追名,生成新的文件名
    String originalFilename = bookFile.getOriginalFilename();//获取原文件名
    String str = originalFilename.substring(originalFilename.lastIndexOf("."));//截取后缀名
    String fileName = System.currentTimeMillis() + str; //利用当前系统时间的毫秒值设置新的文件名
    //2.获取imges目录在服务器的路径
    String dir = request.getServletContext().getRealPath("imges");
    String savePath = dir + "/" + fileName;
    //3.保存文件
    bookFile.transferTo(new File(savePath));
    //4.将图片路径设置到book对象
    book.setBookimge("imges/" + fileName );
    //调用service保存book对象
    return "/tips.jsp";
}
4.2 运行结果
  • 前端提交文件

在这里插入图片描述

  • debugger查看提交的数据

在这里插入图片描述

  • 放行-页面跳转

在这里插入图片描述

  • 查看是否上传成功

在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于Spring MVC来说,文件上传和下载是常见的功能之一。下面是关于如何实现文件上传和下载的基本步骤: 1. 文件上传: - 在Spring MVC的配置文件中,添加`CommonsMultipartResolver`来解析文件上传请求。 - 创建一个表单页面,使用`enctype="multipart/form-data"`属性,确保可以上传文件。 - 在Controller中创建一个处理文件上传请求的方法,使用`@RequestParam("file") MultipartFile file`注解来接收文件。 - 在方法内部,可以通过`file.getInputStream()`来获取文件的输入流,进而实现上传操作。 2. 文件下载: - 在Controller中创建一个处理文件下载请求的方法。 - 在方法内部,使用`HttpServletResponse`对象设置响应头信息,包括`Content-Disposition`和`Content-Type`。 - 通过`response.getOutputStream()`获取输出流,并将文件的内容写入输出流。 需要注意的是,为了确保文件上传和下载的安全性,可以进行一些额外的处理,例如限制文件类型、大小等。 以下是一个示例代码,用于演示文件上传和下载: ```java @Controller public class FileController { @Autowired private ServletContext servletContext; @RequestMapping(value = "/upload", method = RequestMethod.POST) public String upload(@RequestParam("file") MultipartFile file) { try { String fileName = file.getOriginalFilename(); String filePath = servletContext.getRealPath("/uploads/") + fileName; file.transferTo(new File(filePath)); return "redirect:/success"; } catch (Exception e) { e.printStackTrace(); return "redirect:/error"; } } @RequestMapping(value = "/download", method = RequestMethod.GET) public void download(HttpServletResponse response) { try { String fileName = "example.txt"; String filePath = servletContext.getRealPath("/downloads/") + fileName; File file = new File(filePath); InputStream inputStream = new FileInputStream(file); response.setHeader("Content-Disposition", "attachment; filename=" + fileName); response.setContentType("application/octet-stream"); IOUtils.copy(inputStream, response.getOutputStream()); response.flushBuffer(); inputStream.close(); } catch (Exception e) { e.printStackTrace(); } } } ``` 上述代码中,`servletContext.getRealPath()`方法用于获取文件的实际路径,`IOUtils.copy()`方法用于将文件内容写入输出流。 请注意,上述示例仅为演示目的,实际应用中可能需要进行更多的异常处理、文件校验等操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值