VUE + SSM + ElementUI 图片上传失败,访问后台接口时报400错误

最近在做vue + SSM 前后端分离项目的时候遇到了图片上传失败的错误。经过一番查询,发现问题如下:

后台无法解析MultipartFile,需要将该过程托管给Spring。

Springmvc中,文件上传通过MultipartResolver实现,故只需要在Spring-mvc.xml中注册MultipartResolver即可。

MultiPartResolver实现类有两个:

  1. CommonsMultipartResolver
  2. StandardServletMultipartResolver

第一个需要使用commons-fileupload的jar包支持,但没有对servlet版本的要求。第二个必须使用servlet3以上的版本

具体操作:

第一步:在pom.xml中添加依赖

<!-- https://mvnrepository.com/artifact/commons-fileupload/commons-fileupload -->
<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.3.3</version>
</dependency>

需要1.2以上版本

第二步:配置一个bean:

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
		<property name="maxUploadSize" value="104857600" />
		<property name="defaultEncoding" value="UTF-8" />
</bean>

maxUploadSize默认值为-1,表示最大上传文件大小

第三步:可以直接写controller了

@ResponseBody
    @RequestMapping("/showImage")
    public String showImage(@RequestParam("file") MultipartFile file) throws Exception{
		System.out.println(file);
    	//判断文件类型
        String fType=file.getContentType();
        assert fType != null;
        String fileType = fType.substring(fType.indexOf("/")+1);
        if("jpeg".equals(fileType)){
            fileType="jpg";
        }
        long time=System.currentTimeMillis();
        //保存文件的绝对路径
        String filename = "items" + time; //保证所有文件名都不相同
        String path="/*这里填文件路径*/"+filename+"."+fileType;
        try{
            file.transferTo(new File(path));
        }catch (Exception e){
            e.printStackTrace();
        }
        fileUrl = filename;
        System.out.println(fileUrl);
        return "ok";
    }

附上我的前端VUE代码

<el-upload
    accept="image/jpg,image/jpeg"
    class="avatar-uploader"
    action="http://localhost:xxxx/xxx/showImage" 这里写后端接口地址
    name="file"
    :limit="1"
    :show-file-list="false"
    :on-success="handleAvatarSuccess"
    :before-upload="beforeAvatarUpload"
>
  <img v-if="imageUrl" :src="imageUrl" class="avatar" alt="">
  <i v-else class="el-icon-plus avatar-uploader-icon"></i>
</el-upload>

只需要修改action内容即可,其他方法和属性用法直接参照ElementUI官方文档即可

参考

https://blog.csdn.net/just4you/article/details/70162605

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值