vue2+ summernote 文件上传

6 篇文章 0 订阅

在mounted 里面加载插件
在页面里写入summernote

                <div name="summernote" ref="summernote"></div>

在js里面加载:

  $(this.$refs.summernote).summernote({
      minHeight: 250,
      lang: "zh-CN",
      callbacks: {
        onImageUpload: (uploadFile=>{
          var formData = new FormData();
          formData.append("uploadFile", uploadFile[0]);
          let config = {
            headers: {
              "Content-Type": "multipart/form-data"
            }
          };
          this.$http
          //第一个参数是上传地址,字符串类型
          //第二个是表单数据
          //第三个是上传配置
            .post(this.API.IMAGE_UPLOAD_ADDRESS, formData, config)
            .then(response => { 
                //以下是默认
              $(this.$refs.summernote).summernote('insertImage',response.data,'img'); 
            });
        })
      }
    });

然后就可以正常上传

controller里面的写法:

 @PostMapping(path = "/v1/upload")
    public String upload(MultipartFile uploadFile, HttpServletRequest request, Map<String, String> params) throws IOException {
        Optional.ofNullable(uploadFile).orElseThrow(() -> new CustomerException("文件不存在"));
        String fileName = uploadFile.getOriginalFilename();
        String leftPath = request.getServletContext().getRealPath("/images");
        File file = new File(leftPath, fileName);
        if (!file.getParentFile().exists()) {
            file.getParentFile().mkdirs();
        }
        if (file.exists() && file.isFile()) {
            file.delete();
        }
        uploadFile.transferTo(file);
        //我使用的是阿里云的方式保存文件。你可以保存在自己服务器里面
        OSSTools tools = new OSSTools();
        String type = fileName.substring(fileName.lastIndexOf(".") + 1);
        String fileType = "image/" + type;
        fileName = UUID.randomUUID().toString() + "." + type;

        String logoPath = tools.uploadObj("image", fileName, file, fileType);
        LOGGER.info(logoPath);
        //然后返回路径
        return logoPath;
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值