欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

SpringBoot的文件上传

程序员文章站 2022-06-03 08:51:01
...

这几天通过学习springboot教程,学习了文件的上传,在此说一下如何上传文件。

(为了更好的显示效果我们这里用上传图片为例)

在此就不讲如何创建项目等知识了,直接上代码。

1.创建UploadFileController.java控制器

package com.project.springboot.web;

import org.springframework.data.domain.Page;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.http.HttpServletRequest;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;

@Controller
public class UploadFileController {
    //这是上传的页面
    @RequestMapping("/uploadPage")
    public String uploadPage() {
        return "uploadPage";
    }
    //上传文件肯定要使用POST来接受
    @RequestMapping(value = "/upload", method = RequestMethod.POST)
    //接受上传的文件,为MultipartFile
    public String upload(HttpServletRequest request, @RequestParam("file")MultipartFile file, Model model) {
        try {
            //根据时间戳来创建新的文件名,这样的话如果是第二次上传相同名称的文件,也不会把第一次        
            //的文件所覆盖
            String fileName = System.currentTimeMillis()+file.getOriginalFilename();
            //通过req.getServletContext().getRealPath("") 获取当前项目的真实路径,然后拼接前面的文件名,
            //意思是会在项目中新建一个uploaded的文件夹用于存放上传的文件
            String destFileName = request.getServletContext().getRealPath("")+"uploaded"+File.separator+fileName;
            //第一次运行的时候,这个文件所在的目录是不存在的,所以这里我们需要创建目录
            File destFile = new File(destFileName);
            destFile.getParentFile().mkdir();
            //把浏览器上传的文件复制到希望的位置
            file.transferTo(destFile);
            //把文件名放在model里,以便后续显示用
            model.addAttribute("fileName", fileName);
        } catch (FileNotFoundException e) {
            e.printStackTrace();
            return "上传失败," + e.getMessage();
        } catch (IOException e) {
            e.printStackTrace();
            return "上传失败," + e.getMessage();
        }
        //上传成功则会跳转到showImage.jsp页面去显示该图片
        return "showImage";
    }
}

2.修改application.properties文件

spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp
server.port=8080
//这里增加了上传文件的大小限制
spring.http.multipart.max-file-size=100Mb
spring.http.multipart.max-request-size=100Mb

3.新建uploadPage.jsp和showImage.jsp

      uploadPage.jsp

<%--
  Created by IntelliJ IDEA.
  User: JIANNIN
  Date: 2018/7/26
  Time: 10:00
  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>
<form action="upload" method="post" enctype="multipart/form-data">
    选择图片:<input type="file" name="file" accept="image/*"> <br>
    <input type="submit" value="上传">
</form>
</body>
</html>

这里选择图片的input中accept="image/*"表示只接受图片格式的文件

需要上传其他类型的文件,进行修改即可

一下列出一些上传的限制

1.accept=”application/msexcel” 
2.accept=”application/msword” 
3.accept=”application/pdf” 
4.accept=”application/poscript” 
5.accept=”application/rtf” 
6.accept=”application/x-zip-compressed” 
7.accept=”audio/basic” 
8.accept=”audio/x-aiff” 
9.accept=”audio/x-mpeg” 
10.accept=”audio/x-pn/realaudio” 
11.accept=”audio/x-waw” 
12.accept=”image/gif” 
13.accept=”image/jpeg” 
14.accept=”image/tiff” 
15.accept=”image/x-ms-bmp” 
16.accept=”image/x-photo-cd” 
17.accept=”image/x-png” 
18.accept=”image/x-portablebitmap” 
19.accept=”image/x-portable-greymap” 
20.accept=”image/x-portable-pixmap” 
21.accept=”image/x-rgb” 
22.accept=”text/html” 
23.accept=”text/plain” 
24.accept=”video/quicktime” 
25.accept=”video/x-mpeg2” 
26.accept=”video/x-msvideo”

这里我限制上传的文件只能为图片,则就是:accept ="image/*";

    showImage.jsp

<%--
  Created by IntelliJ IDEA.
  User: JIANNIN
  Date: 2018/7/26
  Time: 10:12
  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>
<img src="/uploaded/${fileName}">
</body>
</html>

进行测试,运行

SpringBoot的文件上传

进入浏览器,输入http://127.0.0.1:8080/uploadPage

SpringBoot的文件上传

上传图片文件

SpringBoot的文件上传

点击上传

SpringBoot的文件上传

跳转到showImage页面显示图片,再查看下项目目录下有没有新建uploaded目录。

SpringBoot的文件上传

自动创建了uploaded目录,并且文件名自动加了时间戳。

好的,至此大功告成!