Springboot 配合 Vue 保存前端上传的文件

Springboot 配合 Vue 保存前端上传的文件


前言

新建一个 Springboot 项目,前端我使用原生 html 来演示上传,你们用 element 或者其他什么的比较方便。


一、后端代码

@RequestMapping("/upload")
public void upload(MultipartFile multipartFile) throws IOException {
    //获取前端上传的文件
    String fileName = multipartFile.getOriginalFilename();
    //创建文件对象,用于保存文件到该路径
    File file = new File("C:\\Users\\DELL\\Desktop\\文件\\" + fileName);
    //如果上面的路径文件夹没有,则创建文件夹
    if(!file.exists()) {
       //先得到文件的上级目录,并创建上级目录,在创建文件
       file.getParentFile().mkdir();
        try {
            //创建文件
            file.createNewFile();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
    //将上传的文件保存到路径下
    multipartFile.transferTo(file);
}

二、前端

自行安装axios,也可以不用axios

<template>
	<div
		<input type="file" ref="file" @change="upload()">		
	</div>
</template>
<script>
	export default{
		methods:{
			upload(){
				var that = this;
				// 获取到this 赋值个that
				var file = this.$refs.file.files[0];
				// 如果没有文件就返回
			    if(!file){return}
				var data = new FormData();
				// 将文件加入到data中
				data.append("file",file);
				axios.post(
					"/upload",
					data,
				)
				.then(res=>{
					consolo.log(res.data)
				}	
				// 清空文件列表
				this.$refs.file.value=""})
			},
		},
	}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

繁华尽头满是殇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值