使用springboot和vue中实现upload上传组件

 

目录

前言

实现

后端部分

entity层

        controller层

VUE

从elementUI官网选择上传组件

method中定义函数 


前言

        上传组件上传的文件并非真的上传到了服务器,而是通过文件路径读取到文件后,在服务器生成一个完全复制源文件的新的文件(名字不同),上传时系统需要判断是否存在目标路径文件夹,如果不存在,需要先依次创建文件夹在进行上传。同时服务器中的文件使用UUID进行命名来避免重名问题。

实现

后端部分

使用注解来简化代码

entity层

@Builder
@Data
public class MyFile() {
	private String filename;
	private String url;
	private String originalName;
	private String type; // 记录文件类型
	private String size;
	private String status;
	private String message;
}

controller层

@RestController
@RequestMapping("/mine")
public class fileUpload() {
	@PostMapping("/upload")
	public String upload(MultipartFile file, HttpServletRequest request) {
		// 判断文件是否为空 
		if(!file.isEmpty()) {
			// 文件上传根路径,根据需要换成你想要的位置 
			String uploadPath = "C:\Users\Neptune\Desktop\project\uploadPath\upload";
			File uploadDir = new File(uploadPath);
			// 如果上传目录不存在,需要先创建目录 
			if(!uploadDir.exists()) {
				uploadDir.mkdir();
			}
			// 获取原文件名称 
			String originalFilename = file.getOriginalFilename();
			// 获取文件大小,单位为字节byte 
			String fileSize = file.getSize(); 
			//获取URL全路径
			String tmpUrl = request.getRequestURL();
            //获取URL的去host(域名或IP)的部分路径
			String tmpUri = request.getRequestURI();
            // 获取 URL 前缀 
			String urlPrefix = String.valueOf(tmpUrl.substring(0, tmpUrl.length() - tmpUri.length()));
			// 获取文件类型
			String suffixName = originalFilename.substring(OriginalFilename.lastIndexOf("."));
			// 使用 UUID 生成随机新名称
			String fileName = UUID.randomUUID().toString() + suffixName;
			File newFile = new File(uploadPath + "/" + fileName);

            //ObjectMapper为Jackson主要类,通过该类将各个形式的信息和json格式相互转换
			ObjectMapper objectMapper = new ObjectMapper();
			try {
				// 远程文件保存本地
				file.transferTo(newFile);
				MyFile myFile= new MyFile();
				myFile.setSize(fileSize);
				myFile.setOriginalName(originalFilename);
				myFile.setFilename(fileName);
				myFile.setUrl(urlPrefix + "/" + fileName);
				myFile.setType(suffixName);
				myFile.setStatus("SUCCESS");
				myFile.setMessage(originalFilename + " 上传成功!");
				String res = objectMapper.writeValueAsString(myFile); // 将对象转换为 Json 格式进行返回
				return res;
			} catch (IOException e) {
				e.printStackTrace();
				MyFile myFile= new myFile();
				myFile.setStatus("FAILED");
				myFile.setMessage((originalFilename + " 上传失败!");
			}
		} else {
			ObjectMapper objectMapper = new ObjectMapper();
			myFilemyFile= new myFile();
			myFile.setStatus("FAILED");
			myFile.setMessage((originalFilename + " 是空文件!");
		}
	}
}

VUE

从elementUI官网选择上传组件

<el-upload
  class="upload-demo"
  drag
  action="/uploadDemo/mine/upload"
  :on-success="handleUploadSuccess"
  :on-error="handleUploadError"
  name="file"
  :show-file-list="false"
  multiple>
  <i class="el-icon-upload"></i>
  <div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
  <div class="el-upload__tip" slot="tip">只能上传jpg/png文件,且不超过500kb</div>
</el-upload>

method中定义函数 

            handleUploadSuccess(res) {
                this.$message.success('上传成功');
                console.log("上传成功,数据如下:");
                console.log(res);
            },
            handleUploadError() {
                this.$message.error('上传失败');
                this.loading.close();
            },

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Spring BootVue.js来实现图片上传功能。下面是一个基本的示例: 在Spring Boot端,你可以使用`@PostMapping`注解来创建一个处理图片上传请求的控制器方法。你需要使用`MultipartFile`类型的参数来接收上传的文件。然后,你可以使用`transferTo()`方法将文件保存到服务器的指定位置。 ```java @RestController public class UploadController { @PostMapping("/upload") public String uploadFile(@RequestParam("file") MultipartFile file) { try { // 获取文件的字节数组 byte[] bytes = file.getBytes(); // 在这里处理文件保存的逻辑,比如保存到数据库或者文件系统 return "上传成功"; } catch (IOException e) { e.printStackTrace(); return "上传失败"; } } } ``` 在Vue.js端,你可以使用`vue-axios`库来发送文件上传请求。首先,你需要引入必要的依赖和配置: ```javascript // main.js import axios from 'axios' import VueAxios from 'vue-axios' Vue.use(VueAxios, axios) ``` 然后,在Vue组件,你可以创建一个文件选择器,并在选择文件后将其发送到服务器: ```html <template> <div> <input type="file" @change="handleFileUpload"> <button @click="uploadFile">上传</button> </div> </template> <script> export default { data() { return { file: null } }, methods: { handleFileUpload(event) { this.file = event.target.files[0] }, uploadFile() { let formData = new FormData() formData.append('file', this.file) this.axios.post('/upload', formData) .then(response => { console.log(response.data) }) .catch(error => { console.log(error) }) } } } </script> ``` 这样,当你选择文件并点击上传按钮时,Vue组件会将文件发送到Spring Boot端的上传接口。 请注意,以上只是一个简单的示例,你可能还需要添加一些额外的逻辑来处理文件的保存、文件格式的验证等。此外,你还可以使用一些第三方库来简化文件上传的流程,比如`vue-upload-component`或`element-ui`等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值