2.0 vue2+tinymce+springboot实现图片上传与回显

2.0 vue2+tinymce+springboot实现图片上传与回显

1.效果

2.配置

  2.1 在init中添加图片上传函数

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

// 图片上传

     images_upload_handler: (blobInfo, success, failure) => {

       // const img = 'data:image/jpeg;base64,' + blobInfo.base64()

       // success(img)

       if(blobInfo.blob().size/1024/1024>2){

             failure("上传失败,图片大小请控制在 2M 以内")

       }else{

             let params=new FormData()

             params.append('file',blobInfo.blob())

             let config={

                   headers:{

                         "Content-Type":"multipart/form-data"

                   }

             }

             this.axios.post(`/article/upload`,params,config).then(res=>{//使用axios进行图片上传,注意this是否引入成功

                 success(res.data)

             }).catch(()=>{

                 failure("上传出错,服务器开小差了呢")

             })

       }

     },

  如果使用axios进行异步上传,请注意this是否引入成功,有时this会指向tinymce而不是全局的vue,如果发生可以在本组件中单独引入axios

  2.2 springboot实现图片上传

1

2

3

4

5

6

7

8

9

10

11

12

13

14

@CrossOrigin//跨域设置,如果存在跨域,需再进行设置,后续文章会进行更新

@RestController

@RequestMapping("/article")

public class ArticleController {

@RequestMapping(value = "/upload")

    // @RequestParam中的file名应与前端的值保持一致

    public String upload(HttpServletResponse  response,@RequestParam("file") MultipartFile multipartFile) throws IOException {

        System.out.println("访问");

        String url=UpLoadFile.uploadPic(multipartFile);

        System.out.println("图片的路径是:"+url);

        url="http://localhost:8090/image/"+url;

        return url;

    }

}

  2.3 图片上传类UpLoadFile

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

package com.maque.util;

import org.springframework.web.multipart.MultipartFile;

import java.io.File;

import java.io.IOException;

import java.util.UUID;

public  class UpLoadFile {

    //判断文件是否存在,存在先进行删除

    public  void fileHasExist(String filePath,String fileName) {

        String path = filePath + fileName;

        File file = new File(path);

        //判断文件夹是否存在如果不存在,则创建该文件夹

        File fileParent = file.getParentFile();

        if(!fileParent.exists()){

            fileParent.mkdirs();

        }

        //判断文件是否存在,存在则删除进行新建,不存在则直接新建

        if(file.exists()){

            file.delete();

            System.out.println("file has exist!");

        }else{

            System.out.println("file has not exist!");

        }

    }

    //上传图片功能

    public static String uploadPic(MultipartFile pictureFile) throws IOException {

        // 图片上传

        // 设置图片名称,不能重复,可以使用uuid

        String picName = UUID.randomUUID().toString();

        // 获取文件名

        String oriName = pictureFile.getOriginalFilename();

        // 获取图片后缀

        String extName = oriName.substring(oriName.lastIndexOf("."));

        // 开始上传保存到指定位置

        pictureFile.transferTo(new File(Constant.PICTURE_LOCATION + picName + extName));

        //pictureFile.transferTo(new File(ResourceUtils.getURL("classpath:").getPath()+"image/" + picName + extName));

        String pName=picName + extName;

        return pName;

    }

}

  Constant.PICTURE_LOCATION是自己定义的文件上传路径的常量

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值