Vue中图片上传到第三方云上,地址存到自己服务器

Vue中为了减少自己服务器的内存,可以通过第三方云服务器来存储地址,把图片的地址存到自己的服务器上

这个案例是用element-ui组件库中的upload组件

只是针对于elment-ui组件库有效,如果使用其他的组件库,需要做更改

  <!-- show-file-list 是否显示文件名字
  before-upload   上传之前的回调函数
  on-success  上传成功的回调函数
  http-request 自定义上传,覆盖默认的上传行为 -->
  <el-upload
    class="avatar-uploader"
    action="#"
    :show-file-list="false"
    :on-success="handleAvatarSuccess"
    :before-upload="beforeAvatarUpload"
    :http-request="upload"
  >
    <!-- <img v-if="imageUrl" :src="imageUrl" class="avatar"> -->
    <img v-if="value" :src="value" class="avatar">
    <i v-else class="el-icon-plus avatar-uploader-icon" />
    <!-- 进度条 -->
    <el-progress v-show="showProgress" :percentage="percent" />
  </el-upload>

第一步先下载包cos-js-sdk-v5

const COS = require('cos-js-sdk-v5')
// 填写自己腾讯云cos中的key和id (密钥)
const cos = new COS({
  SecretId: 'AKIDWLuDHAsKxQecJlvmQIJsAB0a9RrwqbeR', // 身份识别ID
  SecretKey: 'xxx' // 身份秘钥
})

第二步在methods中定义一个方法

 if (res.file) {
        // 当有图片的时候,控制进度条的显示
        this.showProgress = true
        console.log('子组件新图片的地址是', this.value)
        // 执行上传操作
        cos.putObject({
          Bucket: 'renzi-image-1305723434', /* 存储桶 */
          Region: 'ap-beijing', /* 存储桶所在地域,必须字段 */
          Key: res.file.name, /* 文件名 */
          StorageClass: 'STANDARD', // 上传模式, 标准模式
          Body: res.file, // 上传文件对象
          onProgress: (progressData) => { // 上传进度
            console.log(JSON.stringify(progressData))
            this.percent = progressData.percent * 100 // 为什么要乘以100呢,因为进度条用的组件elmentui要求的
          }
        }, (err, data) => {
          if (err) {
            this.$message.error(err.message)
          } else {
            // 上传成功之后
            if (data.statusCode === 200) {
            //   this.imageUrl = `https:${data.Location}`
              this.$emit('input', `https:${data.Location}`)
              this.$message.success('操作成功')
            }
          }
          this.showProgress = false
        })
      }

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值