Base64文件上传到后台服务器

  1. 引入axios

npm install axios

  1. 前台输入
// 绑定@imgAdd event
    $imgAdd(pos, $file) {
      // 第一步.获取图片信息
      var formdata = new FormData();
      formdata.append('file', $file);
      console.log($file);
      // 存储图片信息
      // [0]base64数据 [1]文件名称
      let fileInfo = [];
      fileInfo[0]=$file.miniurl.split(',')[1];
      fileInfo[1]=$file._name;
      //图片上传服务器
      axios({
        url: process.env.VUE_APP_BASE_API + "/common/uploadBase64",
        method: 'post',
        data: fileInfo,
        headers: {
          Authorization: "Bearer " + getToken(),
        },
      }).then((res) => {
        console.log(res);
        
        // 第二步.将返回的url替换到文本原位置![...](0) -> ![...](url)
        // $vm.$img2Url 详情见本页末尾
        this.$refs.md.$img2Url(pos, res.data.url);
      })
    },
  1. Java后台加入依赖
<!--MockMultipartFile 依赖-->
<dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-test</artifactId>
  <version>5.0.5.RELEASE</version>
</dependency>
  1. 后台接收并转换后上传
/**
     * 通用上传base64文件请求(单个)
     * @param fileInfo [0]base64数据 [1]文件名称
     * @return
     */
    @PostMapping("/uploadBase64")
    public AjaxResult uploadFileBase64(@RequestBody String[] fileInfo)
    {
        try
        {
            // 解码Base64数据
            byte[] data = Base64.getDecoder().decode(fileInfo[0]);

            // 创建一个临时的MutlipartFile
            MultipartFile file = new MockMultipartFile("file", fileInfo[1], "image/png", data);

            // 上传文件路径
            String filePath = RuoYiConfig.getUploadPath();
            // 上传并返回新文件名称
            String fileName = FileUploadUtils.upload(filePath, file);
            String url = serverConfig.getUrl() + fileName;
            AjaxResult ajax = AjaxResult.success();
            ajax.put("url", url);
            ajax.put("fileName", fileName);
            ajax.put("newFileName", FileUtils.getName(fileName));
            ajax.put("originalFilename", file.getOriginalFilename());
            return ajax;
        }
        catch (Exception e)
        {
            e.printStackTrace();
            return AjaxResult.error(e.getMessage());
        }
    }
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

程似锦吖

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

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

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

打赏作者

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

抵扣说明:

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

余额充值