springboot+thymeleaf 文件上传功能的实现代码

网友投稿 696 2023-03-07

springboot+thymeleaf 文件上传功能的实现代码

springboot+thymeleaf 文件上传功能的实现代码

pom.xml

org.springframework.boot

spring-boot-starter-thymeleaf

org.springframework.boot

spring-boot-starter-web

application.yml

spring:

servlet:

multipart:

#上传文件总的最大值

max-request-size: 10MB

#上传文件的最大值

max-file-size: 10MB

index.html 文件上传页面

单文件上传

多文件上传

文件1:

文件2:

hello.html 上传成功的页面

单文件上传

多文件上传

controller:  文件上传

import org.springframework.core.io.ResourceLoader;

import org.springframework.http.ResponseEntity;

import org.springframework.stereotype.Controller;

import org.springframework.ui.Model;

import org.springframework.util.ResourceUtils;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RequestParam;

import org.springframework.web.multipart.MultipartFile;

import org.springframework.web.multipart.MultipartRequest;

import javax.servlet.http.HttpServletRequest;

import java.io.File;

import java.io.FileNotFoundException;

import java.io.IOException;

import java.text.SimpleDateFormat;

import java.util.ArrayList;

import java.util.Date;

import java.util.List;

import java.util.UUID;

@Controller

public class FileUploadController {

//单一文件上传

@RequestMapping("/upload")

public String uploadFile(@RequestParam("file00") MultipartFile file, Model model){

String msg="";

try {

if(file.isEmpty()){

model.addAttribute("msg","上传失败,请选择文件!");

return "index";

}

String filename = file.getOriginalFilename();

//String filePath = request.getServletContext().getRealPath("/upload");

String filePath = ResourceUtils.getURL("classpath:").getPath()+"static/";

//避免文件重复覆盖

String uuid= UUID.randomUUID().toString().replaceAll("-", "");

//时间戳分类文件

String time = new SimpleDateFormat("YYYY-MM").format(new Date());

String realPath = filePath+time+"/"+uuid+filename;

File dest = new File(realPath);

//检测是否存在目录,无,则创建

if(!dest.getParentFile().exists()){

dest.getParentFile().mkdirs();//新建文件夹 多级目录

}

file.transferTo(dest);//文件写入

} catch (IOException e) {

e.printStackTrace();

}

model.addAttribute("msg","文件上传成功!");

return "hello";

}

//多文件上传

@RequestMapping("/batch")

public String uploadMoreFiles(HttpServletRequest request, Model model){

MultipartRequest request1 = (MultipartRequest)request;

//猜测 file为 input 类型为 file

List fileList = request1.getFiles("file");

List msgList = new ArrayList<>();

System.out.println(fileList.size());

try {

String filepath = ResourceUtils.getURL("classpath:").getPath()+"static/";

for (int i=1;i<=fileList.size();i++){

MultipartFile file = fileList.get(i-1);

if (file.isEmpty()){

msgList.add("上传第"+i+"个文件失败");

model.addAttribute("msgList",msgList);

continue;

}

String filename = file.getOriginalFilename();

//避免文件重复覆盖

String uuid= UUID.randomUUID().toString().replaceAll("-", "");

//时间戳分类文件

String time = new SimpleDateFormat("YYYY-MM").format(new Date());

String realPath = filepath+time+"s/"+uuid+filename;

File dest = new File(realPath);

//System.out.println("realPath"+realPath);

//检测是否存在目录,无,则创建

if(!dest.getParentFile().exists()){

dest.getParentFile().mkdirs();//新建文件夹pviifKN 多级目录

}

msgList.add("第"+i+"个文件,上传成功!");

file.transferTo(dest);

}

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

model.addAttribute("msgList",msgList);

return "hello";

}

}

测试:

注:目前仅实现了文件的上传

计划补充:文件-+上传的图片展示;

上传的图片展示:

遇到的问题:  直接使用 realPath 作为图片拼接地址  浏览器报 安全错误

使用字符串拼接,也会报错404

index = realPath.lastIndexOf("static");

upFilePaths.add("../"pviifKN+realPath.substring(index));

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信电脑端打开小程序(微信电脑端打开小程序怎么操作)
下一篇:vue php开发小程序(vue小程序开发教程)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~