先上两段相关代码:
package com.biu.chapter04_file_upload;
import com.alibaba.fastjson.JSON; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.multipart.MultipartFile;
import javax.servlet.http.HttpServletRequest; import java.io.File; import java.io.IOException; import java.text.SimpleDateFormat; import java.util.Arrays; import java.util.Date; import java.util.UUID;
@RestController public class FileUploadController { SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd/");
public static final Logger LOG = LoggerFactory.getLogger(FileUploadController.class);
@PostMapping("/uploads") public String upload(MultipartFile[] uploadFiles, HttpServletRequest req) { LOG.info("---------------------------------------"); LOG.info(Arrays.toString(uploadFiles)); String realPath = req.getSession().getServletContext().getRealPath("uploadFile"); String format = sdf.format(new Date()); File folder = new File(realPath + format); if (!folder.isDirectory()) { folder.mkdirs(); }
try { for (MultipartFile uploadFile : uploadFiles) { String oldName = uploadFile.getOriginalFilename(); String newName = UUID.randomUUID().toString() + oldName.substring(oldName.lastIndexOf("."), oldName.length()); uploadFile.transferTo(new File(folder, newName)); String filePath = req.getScheme() + "://" + req.getServerName() + ":" + req.getServerPort() + "/uploadFile" + format + newName; System.out.println("filePath = " + filePath); } return "上传成功!"; } catch (IOException e) { e.printStackTrace(); } return "上传失败!"; } }
|
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>uploads</title> </head> <body> <p>MultipartFile upload</p>
<form action="uploads" method="POST" enctype="multipart/form-data"> File: <input type="file" name="uploadFiles" multiple="multiple"/> <input type="submit" value="submit" /> </form> </body> </html>
|
这两段代码的功能就是简单的上传文件,下面我将尝试分析一下上面的Java代码:
SimpleDateFormat sdf = new SimpleDateFormat("yyyy/MM/dd/");
|
这个构造参数的传参为描述日期和时间格式的String,作用是使用给定模式和默认语言环境的默认日期格式符号构造一个FORMAT。官方文档有描述:https://docs.oracle.com/javase/8/docs/api/java/text/SimpleDateFormat.html
public static final Logger LOG = LoggerFactory.getLogger(FileUploadController.class);
|
引入slf4j来打印日志,主要作用是分析代码,使用静态绑定的ILoggerFactory实例,返回与作为参数传递的类对应的记录器。官方文档有描述:SLF4J 手册
接下来是上传文件的公有方法,传参为HttpServletRequest对象和一个MultipartFile[]对象数组,相关文档:
MultipartFile
HttpServletRequest
String realPath = req.getSession().getServletContext().getRealPath("uploadFile");
|
这行代码用来获取项目运行目录下的uploadFile文件夹,作用是用来存放上传的文件,其中getSession()方法的作用是返回与此请求关联的HttpSession,然后调用getServletContext()返回web应用程序的ServletContext对象,最后调用getRealPath()方法来返回一个包含真实路径的字符串。
使用logger打印出来的结果如下:
在当前应用运行的上下文环境中获取uploadFile文件夹C:\Users\***\AppData\Local\Temp\tomcat-docbase.8080.8757276750274673738\uploadFile
|
String format = sdf.format(new Date());
|
返回一个格式化的String,内容为当前时间,结果为:“2022/01/26/”
File folder = new File(realPath + format);
|
把两个String拼接了一下,结果为:“ C:\Users***\AppData\Local\Temp\tomcat-docbase.8080.8757276750274673738\uploadFile2022\01\26”。再进行下一步的判断逻辑,并根据结果来判读是否新建文件夹。
在try……catch里面循环文件数组对象,并进行相应的逻辑处理:
String oldName = uploadFile.getOriginalFilename(); String newName = UUID.randomUUID().toString() + oldName.substring(oldName.lastIndexOf("."), oldName.length());
|
这两行代码用来给文件重命名,比较简单。
uploadFile.transferTo(new File(folder, newName));
|
用来对文件进行上传操作,将接收到的文件传输到给定的目标文件,上传完成之后,将字符串简单拼接一下就得到我们上传文件的url地址了!transferTo的文档在这:https://docs.spring.io/spring-framework/docs/current/javadoc-api/org/springframework/web/multipart/MultipartFile.html