ElementuiPlus文件上传失败原因,一个小坑记录!

记录一个自己犯得错误,一定记住要前后端file名字对应上!

原后端代码

java 复制代码
@RestController
@RequestMapping("/upload")
public class UploadFileController {
    @PostMapping
    public Result upload(MultipartFile multipartFile) throws IOException {
        System.out.println("hhh"+multipartFile);
//        原始文件名
        String originFileName = multipartFile.getOriginalFilename();
//        名字重组
        String filename = UUID.randomUUID().toString().substring(1, 6) + originFileName.substring(originFileName.lastIndexOf("."));
//        使用阿里云工具类上传,返回一个url地址
        String url = AliOssUtil.uploadFile(filename, multipartFile.getInputStream());
        return Result.success(url);
    }
}

原前端组件代码

java 复制代码
                <el-col :span="8">
                    <el-upload class="avatar-uploader" :show-file-list="false" :auto-upload="true" action="/api/upload"
                         name="file" :headers="{ 'Authorization': tokenStore.token }" :on-success="uploadSuccess">
                        <img v-if="imgUrl" :src="imgUrl" class="avatar" />
                        <img v-else src="@/assets/avatar.jpg" width="150px" height="150px" />
                    </el-upload>
                </el-col>

由于自己写的时候没注意到,·< el-upload> ·组件这里的name属性已经复制了名字为"file",也就是我们上传文件后,文件给后端时候,名字是file,后端要去拿这个文件的话,就会使用的MultipartFile,后端这里必须也是file名字命名。

所以前后端只要file名字一致即可

方法一、@RequestParam("file")注解明确前端名字file

java 复制代码
 public Result upload(@RequestParam("file") MultipartFile multipartFile) throws IOException

方法二、 不用获取前端信息的注解,将MultipartFile对象名字为file也是可以的

java 复制代码
public Result upload(MultipartFile file) throws IOException

记录一下MultipartFile 的知识点

MultipartFile 它是 Spring Framework 提供的一个接口,用于表示通过 HTTP 请求上传的文件数据。MultipartFile 接口提供了一些常用的方法,用于获取文件的相关信息和操作文件数据。以下是一些常用的方法:

  • getOriginalFilename():获取上传文件的原始文件名。
  • getBytes():将文件内容作为字节数组返回。
  • getSize():获取文件的大小。
  • getInputStream():获取文件内容的输入流。
  • transferTo(File dest):将上传的文件保存到指定的目标文件中。
相关推荐
阿湯哥10 分钟前
Spring AI Alibaba 实现 Workflow 全指南
java·人工智能·spring
旺仔小拳头..38 分钟前
Java ---变量、常量、类型转换、默认值、重载、标识符、输入输出、访问修饰符、泛型、迭代器
java·开发语言·python
12344521 小时前
【面试复盘】有了equals为什么还要hashcode
java·后端
毕设源码-邱学长1 小时前
【开题答辩全过程】以 台球俱乐部管理系统为例,包含答辩的问题和答案
java·eclipse
蜗牛^^O^1 小时前
java中的JUC
java·开发语言
进阶小白猿1 小时前
Java技术八股学习Day17
java·jvm·学习
带刺的坐椅1 小时前
从 Chat 到 Agent:Solon AI 带你进入“行动派”大模型时代
java·ai·agent·solon·mcp·java25
扶苏-su2 小时前
Java--转换流-InputStreamReader 和 OutputStreamWriter
java·开发语言
我是小疯子662 小时前
深度学习实现智能文本摘要
java
heartbeat..2 小时前
SQL 常用函数大全:聚合、字符串、数值、日期、窗口函数解析
java·数据库·sql·函数