文件上传介绍
data:image/s3,"s3://crabby-images/dc562/dc562c742c9f3f00fba0a8e36abbb5f310a0129f" alt="请添加图片描述"
data:image/s3,"s3://crabby-images/78b20/78b20a05d50e441b4f6fd1eb6dfff8418eb37291" alt="请添加图片描述"
data:image/s3,"s3://crabby-images/53482/53482521c27deff6e37c0f88e82425161738e507" alt="请添加图片描述"
文件上传代码实现
data:image/s3,"s3://crabby-images/65d6f/65d6f9c5b521ec6914c68bcd71a6817e459b6d36" alt="请添加图片描述"
page>demo>复制upload.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>文件上传</title>
<link rel="stylesheet" href="../../plugins/element-ui/index.css" />
<link rel="stylesheet" href="../../styles/common.css" />
<link rel="stylesheet" href="../../styles/page.css" />
</head>
<body>
<div class="addBrand-container" id="food-add-app">
<div class="container">
<el-upload class="avatar-uploader"
action="/common/upload"
:show-file-list="false"
:on-success="handleAvatarSuccess"
:before-upload="beforeUpload"
ref="upload">
<img v-if="imageUrl" :src="imageUrl" class="avatar"></img>
<i v-else class="el-icon-plus avatar-uploader-icon"></i>
</el-upload>
</div>
</div>
<script src="../../plugins/vue/vue.js"></script>
<script src="../../plugins/element-ui/index.js"></script>
<script src="../../plugins/axios/axios.min.js"></script>
<script src="../../js/index.js"></script>
<script>
new Vue({
el: '#food-add-app',
data() {
return {
imageUrl: ''
}
},
methods: {
handleAvatarSuccess (response, file, fileList) {
this.imageUrl = `/common/download?name=${response.data}`
},
beforeUpload (file) {
if(file){
const suffix = file.name.split('.')[1]
const size = file.size / 1024 / 1024 < 2
if(['png','jpeg','jpg'].indexOf(suffix) < 0){
this.$message.error('上传图片只支持 png、jpeg、jpg 格式!')
this.$refs.upload.clearFiles()
return false
}
if(!size){
this.$message.error('上传文件大小不能超过 2MB!')
return false
}
return file
}
}
}
})
</script>
</body>
</html>
查看效果
data:image/s3,"s3://crabby-images/ef8eb/ef8eb430bf80117389dd2f79162b610ff7e4946e" alt="请添加图片描述"
data:image/s3,"s3://crabby-images/a8db4/a8db450178b05d7b2e64d92dd6b231fd8f5721ca" alt="请添加图片描述"
当我们选择一张图片的时候,他会自动的发送请求到服务端,所以下面编写服务端,来处理这个请求
新建CommonController类
主要进行文件的上传和下载
package com.taotao.reggie.controller;
import com.taotao.reggie.common.R;
import lombok.extern.slf4j.Slf4j;
import lombok.extern.slf4j.XSlf4j;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
@SuppressWarnings({"all"})
@RestController
@RequestMapping("/common")
@Slf4j
public class CommonController {
@PostMapping("/upload")
public R<String> upload(MultipartFile file){
return null;
}
}
注意,此file参数必须要与payload中name = 'file’一致
data:image/s3,"s3://crabby-images/57300/573007e0f7e4caf44c6b83f03b9ad79c9049d5ae" alt="请添加图片描述"
断点测试
可以看到,这个文件目前是个临时文件状态,所以我们给他转存一下,否则本次请求完成后,这个临时文件会消失
data:image/s3,"s3://crabby-images/e6ab0/e6ab07928c415b835b556aec0d91c89518e0d989" alt="请添加图片描述"
尝试寻找临时文件
data:image/s3,"s3://crabby-images/c3b8d/c3b8d17bd2b90522256984dffb05d12ee92d7bac" alt="请添加图片描述"
上传文件时传输的临时文件,被存放在c盘的temp内的更深的文件夹中
这个temp文件夹是我清理c盘时必清的文件夹,他就是系统缓存文件夹
这就是我们上传和下载文件的一个过程吧,他需要那么一个tmp类型文件来进行交互,当我们得到源文件时,这个tmp文件才会消失
data:image/s3,"s3://crabby-images/05afa/05afa3d86132db2bb96808aa007fc1c6b0a09c43" alt="请添加图片描述"
转存文件
file.transferTo(new File(“D:\dishs”));
package com.taotao.reggie.controller;
import com.taotao.reggie.common.R;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import java.io.File;
import java.io.IOException;
@SuppressWarnings({"all"})
@RestController
@RequestMapping("/common")
@Slf4j
public class CommonController {
@PostMapping("/upload")
public R<String> upload(MultipartFile file){
log.info(file.toString());
try {
file.transferTo(new File("D:\\dishs.jpg"));
} catch (IOException e) {
System.out.println("转存文件失败...");
e.printStackTrace();
}
return null;
}
}
取消拦截器过滤LoginCheckFilter.java
添加common/**,使common文件夹下资源不用登陆也可以使用
data:image/s3,"s3://crabby-images/bc240/bc2408750ab5169b13bb4babf6c1b984e2f4d2e8" alt="请添加图片描述"
运行测试
转存成功
data:image/s3,"s3://crabby-images/e7dd7/e7dd75f7acfebf2057d40d0012290d413ae55cca" alt="请添加图片描述"
完善功能
配置准确路径
编写application.xml
data:image/s3,"s3://crabby-images/a9ded/a9ded1c8fb961fd9a0ccd02144165979a1375df1" alt="请添加图片描述"
编写CommonController.java
data:image/s3,"s3://crabby-images/3fe8f/3fe8f21c66d53185fcaa31daf1eccfc420c3ffbf" alt="请添加图片描述"
data:image/s3,"s3://crabby-images/ebf80/ebf801707cc28606bf90b29194234cb57a2ac980" alt="请添加图片描述"
运行测试
成功
data:image/s3,"s3://crabby-images/e278b/e278bf0a423b92e1798fe226a6ec6867a7e7acf2" alt="请添加图片描述"
完善二级目录
编写application.yml
data:image/s3,"s3://crabby-images/5dc7a/5dc7a138e6688b98911cab524beb7635dbb6506f" alt="在这里插入图片描述"
编写CommonControler.java
package com.taotao.reggie.controller;
import com.taotao.reggie.common.R;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;
import java.io.File;
import java.io.IOException;
import java.util.UUID;
@SuppressWarnings({"all"})
@RestController
@RequestMapping("/common")
@Slf4j
public class CommonController {
@Value("${reggie.path}")
private String basePath;
@PostMapping("/upload")
public R<String> upload(MultipartFile file){
log.info(file.toString());
String originalFilename = file.getOriginalFilename();
String suffix = originalFilename.substring(originalFilename.lastIndexOf("."));
String fileName = UUID.randomUUID().toString() + suffix;
File dir = new File(basePath);
if(!dir.exists()){
dir.mkdir();
}
try {
file.transferTo(new File(basePath + fileName));
} catch (IOException e) {
System.out.println("转存文件失败...");
e.printStackTrace();
}
return R.success(fileName);
}
}
测试成功
data:image/s3,"s3://crabby-images/8e828/8e828864e879d8b5359870b7ccc930074944e8a3" alt="在这里插入图片描述"
|