当前位置 : 主页 > 编程语言 > java >

Spring Boot实现文件上传功能

来源:互联网 收集:自由互联 发布时间:2022-08-15
前端处理 通过form表单来上传文件 提交方式为post enctype格式为"multipart/form-data" input类型为file name属性必须和Controller中方法的形参名称一致 !DOCTYPE html html lang="en" head meta charset="UTF-8" tit

前端处理

  • 通过form表单来上传文件
  • 提交方式为post
  • enctype格式为"multipart/form-data"
  • input类型为file
  • name属性必须和Controller中方法的形参名称一致
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h2>用户注册</h2>
<form action="/register" method="post" enctype="multipart/form-data">
用户名:<input type="text" name="username"><br><br>
密码 :<input type="password" name="password"><br><br>
头像 :<input type="file" name="uploadFile"><br><br>
<input type="submit" value="提交">
</form>
</body>
</html>

后端处理

创建一个数据库用来保存登录的用户名,密码,文件名

Spring Boot实现文件上传功能_html

我们可以写一个工具类

public class UUIDUtils
public static String createNewUUID(){
String uuid = UUID.randomUUID().toString();
//如果要把uuid的-去掉替换成空字符串 然后需要把32为字符串变成64字符串
uuid = uuid.replace("-", "");
return

实体类User

@Data
public class User{
private Integer id;
private String username;
private String password;
private

Controller

@Controller
public class UserController{
@Autowired
private UserService userService;

/**
* 显示注册画面
* @return
@RequestMapping("/show")
public String show(){
return "/page/register.html";
}
@PostMapping("/register")
public String register(User user, @RequestParam("uploadFile"){
System.out.println("用户:"+user);
System.out.println("文件:"+uploadFile);
//创建本地文件
//思考文件名,文件名要是唯一的 必须要保证每一个用户注册上传的图片,文件等,必须保存成唯一的文件名
//Java技术 Java UUID User Unique ID 本身用于给用户指定唯一的ID,可以用它来产生唯一的随机字符串
//uuid默认返回的是32位字母组成的随机字符串,重复的概率几乎为0
//创建唯一文件名
String fileName= UUIDUtils.createNewUUID();
//我们需要文件的后缀也应该不是写死的,前端上传的后缀是啥,我们保存的就是什么
//获取原生文件的文件名
String originalFilename = uploadFile.getOriginalFilename();
System.out.println(originalFilename);
//创建文件的后缀名
String suffix = originalFilename.substring(originalFilename.lastIndexOf("."));
//创建新的文件路径
String filePath=fileName+suffix;

File srcFile = new File("D:/springboot/download/img/"+filePath);
try {
//把前端传送的文件保存在本地中
uploadFile.transferTo(srcFile);
} catch (IOException e) {
e.printStackTrace();
}
user.setFilename(filePath);
try {
userService.register(user);
} catch (Exception e) {
e.printStackTrace();
}
return "";
}

}

Service

public interface UserService{
void register(User user) throws;
}

Service实现类

@Service
public class UserServiceImpl implements UserService{
@Autowired
private UserMapper userMapper;
@Override
public void register(User user) throws{
userMapper.insert(user);
}
}

Mapper

@Mapper
public interface UserMapper{
@Insert("insert into user values(default,#{username},#{password},#{filename})")
void insert(User user);
}

Spring Boot实现文件上传功能_html_02

Spring Boot实现文件上传功能_java_03

Spring Boot实现文件上传功能_html_04

物理路径和虚拟路径映射

先准备好页面jsp

<%@page language="java" isELIgnored="false" pageEncoding="UTF-8" contentType="text/html; UTF-8"
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h2>文件的上传</h2>
<form action="/file/upload" method="post" enctype="multipart/form-data">
文件上传:<input type="file" name="uploadFile"><br><br>
<input type="submit" value="提交">
</form>
</body>
</html><%@page language="java" isELIgnored="false" pageEncoding="UTF-8" contentType="text/html; UTF-8"
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<img src="/img/${filePath}">图像</img>
路径:${filePath}
</body>
</html>

编写Controller

@Controller
@RequestMapping("/file")
public class FileUploadController{
/**
* 显示画面
* @return
@RequestMapping("/show")
public String show(){
return "file.jsp";
}

@RequestMapping(value = "/upload",method = RequestMethod.POST)
public String fileUpload(MultipartFile uploadFile, HttpSession session){
//利用uuid创建唯一的字符串 让这个字符串作为文件名
String fileName = UUIDUtils.createNewUUID();

//获取上传文件的文件名
String originalFilename = uploadFile.getOriginalFilename();
//获取后缀名
String suffix = originalFilename.substring(originalFilename.lastIndexOf("."));
//创建文件保存路径
String filePath=fileName+suffix;
File srcFile=new File("D:/springboot/download/img/"+filePath);
//把前端文件保存在本地
try {
uploadFile.transferTo(srcFile);
//把文件存放在本地的文件路径保存在session域中
session.setAttribute("filePath", filePath);

} catch (IOException e) {
e.printStackTrace();
}
//我们希望网页上可以把图片显示出来
System.out.println("文件存放路径:"+filePath);
return "show.jsp";
}

}

Spring Boot实现文件上传功能_html_05

不过,我们可以发现,当我们点击提交的时候,图片还是无法显示

Spring Boot实现文件上传功能_文件名_06

Spring Boot实现文件上传功能_文件名_07

@Configuration
public class WebConfig implements WebMvcConfigurer{
//实现资源的虚拟路径和物理路径的映射

@Override
public void addResourceHandlers(ResourceHandlerRegistry registry){
registry.addResourceHandler("/img/**")
.addResourceLocations("file:"+"D:\\springboot\\download\\img\\");
}
}

addResourceHandler(“xxx”) 用于指定对外暴露的访问路径,addResourceLocations(“xxx”) 用于指定文件放置路径


上一篇:Java架构师发展路线
下一篇:没有了
网友评论