SpringMVC实现文件上传

2020-04-07  本文已影响0人  阿杰_96c5

1.传统文件上传方式

1.1导入文件上传的jar包

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

1.2 编写文件上传的JSP页面

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

1.3 编写文件上传的Controller控制器

/**
 * 文件上传
 * @return
 */
@RequestMapping("/fileUpload1")
public String fileUpload1(HttpServletRequest request) throws Exception {
    System.out.println("传统的文件上传...");
    // 使用fileupload组件完成文件上传
    //上传的位置
    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> fileItems = upload.parseRequest(request);
    // 遍历
    for(FileItem item : fileItems){
        // 判断当前item对象是否是上传文件项
        if(item.isFormField()){
            // 说明普通表单项
        }else{
            //说明上传文件项
            // 获取上传文件的名称
            String fieldName = item.getName();
            // 把文件的名称设置成唯一值
            String uuid = UUID.randomUUID().toString().replace("-", "");
            fieldName = uuid + "-" + fieldName;
            // 完成文件上传
            item.write(new File(path,fieldName));

            // 删除临时文件
            item.delete();
        }
    }
    return "success";
}

2 SpringMVC传统方式文件上传

2.1编写文件上传的JSP页面

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

2.2编写文件上传的Controller控制器

SpringMVC框架提供了MultipartFile对象,该对象表示上传的文件,要求变量名称必须和表单file标签的name属性名称相同

/**
 * springMVC文件上传
 * @return
 */
@RequestMapping("/fileUpload2")
public String fileUpload2(HttpServletRequest request, MultipartFile upload) throws Exception {
    System.out.println("springMVC文件上传...");
    // 使用fileupload组件完成文件上传
    //上传的位置
    String path = request.getSession().getServletContext().getRealPath("/uploads");
    // 判断路径是否存在
    File file = new File(path);
    if(!file.exists()){
        // 创建文件夹
        file.mkdir();
    }

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

    return "success";
}

2.3 在springmvc.xml配置文件解析器对象

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

3. SpringMVC跨服务器方式文件上传

3.1 配置图片服务器

首先在tomcat的新端口上重新开启一个tomcat服务器fileuploadserver服务器,并且在webapps下新建一个uploads文件夹

3.2 编写前端jsp代码

<h3>跨服务器文件上传</h3>

<form action="user/fileupload3" method="post" enctype="multipart/form-data">
    选择文件:<input type="file" name="upload" /><br/>
    <input type="submit" value="上传" />
</form>

3.3 编写后端controller 代码

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

    // 定义上传文件服务器路径
    String path = "http://localhost:9090/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";
}
上一篇下一篇

猜你喜欢

热点阅读