【SpringMVC】之 SpringMVC实现文件上传操作-06

1. SpringMVC 文件上传操作

1.1 上传文件的前提

  • form 表单的 enctype 取值必须是: multipart/form-data
    • (默认值是:application/x-www-form-urlencoded)
    • enctype:是表单请求正文的类型
  • method 属性取值必须是 Post
  • 提供一个文件选择域<input type=”file” />

1.2 传统方式上传文件

传统方式的文件上传, 指的是我们上传的文件和访问的应用存在于同一台服务器上。并且上传完成之后,浏览器可能跳转。

pom.xml文件:

    <dependency>
      <groupId>commons-fileupload</groupId>
      <artifactId>commons-fileupload</artifactId>
      <version>1.3.1</version>
    </dependency>

    <dependency>
      <groupId>commons-io</groupId>
      <artifactId>commons-io</artifactId>
      <version>2.4</version>
    </dependency>

JSP代码:

<html>
<head>
    <title>Title</title>
</head>
<body>
    <h3>传统文件上传</h3>
    <form action="/user/fileUpload1" method="post" enctype="multipart/form-data">
        选择文件:<input type="file" name="upload"/><br/>
        <input type="submit" value="上传">
    </form>
</body>
</html>

Java代码:

/**
 * 传统方式文件上传
 * @return
 */
@RequestMapping("/fileUpload1")
public String fileUpload1(HttpServletRequest request) throws Exception {
    System.out.println("传统文件上传......");
    // 使用file upload组建完成文件上传
    // 上传的位置
    String path = request.getSession().getServletContext().getRealPath("/uploads/");
    // 判断该路径是否存在
    File file = new File(path);
    if (!file.exists()) {
        // 创建该文件夹
        file.mkdir();
    }
    // 解析request对象,获取上传文件项
    DiskFileItemFactory factory = new DiskFileItemFactory();
    ServletFileUpload upload = new ServletFileUpload(factory);
    // 解析request
    List<FileItem> items = upload.parseRequest(request);
    // 遍历
    for (FileItem item : items) {
        // 进行判断,当前item对象是否是上传文件项
        if (item.isFormField()) {
            // 说明普通表单项
        } else {
            // 说明上传文件项
            // 获取上传文件的名称
            String filename = item.getName();
            // 把文件名称设置唯一值,uuid
            String uuid = UUID.randomUUID().toString().replace("-", "");
            filename = uuid + "_" + filename;
            // 完成文件上传
            item.write(new File(path, filename));
            // 删除临时文件
            item.delete();
        }
    }
    return "success";
}

1.3 SpringMVC 方式上传文件

SpringMVC框架提供了MultipartFile对象,该对象表示上传的文件,要求变量名称必须和表单file标签的name属性名称相同。在这里插入图片描述请添加图片描述

JSP代码:

<html>
<head>
    <title>Title</title>
</head>
<body>
    <h3>SpringMVC文件上传</h3>
    <form action="/user/fileUpload2" method="post" enctype="multipart/form-data">
        选择文件:<input type="file" name="upload"/><br/>
        <input type="submit" value="上传">
    </form>
</body>
</html>

Java代码:

/**
 * SpringMVC方式文件上传
 *
 * @return
 */
@RequestMapping("/fileUpload2")
public String fileUpload2(HttpServletRequest request, MultipartFile upload) throws Exception {
    System.out.println("SpringMVC文件上传......");
    // 使用file upload组建完成文件上传
    // 上传的位置
    String path = request.getSession().getServletContext().getRealPath("/uploads/");
    System.out.println(path);
    // 判断该路径是否存在
    File file = new File(path);
    if (!file.exists()) {
        // 创建该文件夹
        file.mkdir();
    }
    // 说明上传文件项
    // 获取上传文件的名称
    String filename = upload.getOriginalFilename();
    // 把文件名称设置唯一值,uuid
    String uuid = UUID.randomUUID().toString().replace("-", "");
    filename = uuid + "_" + filename;
    // 完成文件上传
    upload.transferTo(new File(path, filename));
    return "success";
}

配置文件解析器:

<!-- 配置文件解析器对象,要求id名称必须是multipartResolver -->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <!-- 设置上传文件的最大尺寸为 10MB -->
    <property name="maxUploadSize" value="10485760"/> <!--10M-->
    <!-- 设置上传文件的最大尺寸为 5MB
	<property name="maxUploadSize">
		<value>5242880</value>
	</property> -->
</bean>

1.4 SpringMVC 跨服务器方式上传文件

分服务器的目的:

在实际开发中,我们会有很多处理不同功能的服务器。例如:

  • 应用服务器:负责部署我们的应用
  • 数据库服务器:运行我们的数据库
  • 缓存和消息服务器:负责处理大并发访问的缓存和消息
  • 文件服务器:负责存储用户上传文件的服务器

分服务器处理的目的是让服务器各司其职,从而提高我们项目的运行效率
在这里插入图片描述

搭建图片服务器:

  1. 根据文档配置tomcat9的服务器,现在是2个服务器
    在这里插入图片描述
  2. 创建fileupload-server项目,作为图片服务器,用于存放图片的 web 工程
  3. 在文件服务器的 tomcat 配置中加入,允许读写操作。web.xml文件位置:加入内容
    在这里插入图片描述
  4. 加入此行的含义是:接收文件的目标服务器可以支持写入操作

pom.xml文件:

<dependency>
	<groupId>com.sun.jersey</groupId>
	<artifactId>jersey-core</artifactId>
	<version>1.18.1</version>
</dependency>
<dependency>
	<groupId>com.sun.jersey</groupId>
	<artifactId>jersey-client</artifactId>
	<version>1.18.1</version>
</dependency>

JSP代码:

<html>
<head>
    <title>Title</title>
</head>
<body>
    <h3>跨服务器文件上传</h3>
    <form action="/user/fileUpload3" method="post" enctype="multipart/form-data">
        选择文件:<input type="file" name="upload"/><br/>
        <input type="submit" value="上传">
    </form>
</body>
</html>

Java代码:

/**
 * 跨服务器文件上传
 *
 * @return
 */
@RequestMapping("/fileUpload3")
public String fileUpload3(MultipartFile upload) throws Exception {
	System.out.println("跨服务器文件上传...");

    // 定义上传文件服务器路径
    String path = "http://localhost:9090/uploads/";
    // 如果报错:原因是fileupload-server中,E:\Users\IdeaProjects\fileupload-server\out\artifacts\fileupload_server_war_exploded中
    // 没有uploads文件,新建uploads即可

    // 说明上传文件项
    // 获取上传文件的名称
    String filename = upload.getOriginalFilename();
    // 把文件的名称设置唯一值,uuid
    String uuid = UUID.randomUUID().toString().replace("-", "");
    filename = uuid+"_"+filename;

    // 创建客户端的对象
    Client client = Client.create();
    // 和图片服务器进行连接
    WebResource webResource = client.resource(path + filename);
    // 上传文件
    webResource.put(upload.getBytes());

    return "success";
}

版权声明:本文为ShangPanGe原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。