x1nfly
5/14/2019 - 1:59 AM

阿里云OSS单文件上传组件

<template>
  <el-upload
    name="image"
    action="/upload"
    list-type="picture-card"
    :file-list="imageList"
    :before-upload="beforeUpload"
    :on-success="onUploadSuccess"
    :on-change="handleUploadChange"
    :http-request="uploadImg"
  >
    <i class="el-icon-plus"></i>
    <div class="el-upload__tip" slot="tip">只支持 jpg/png 文件,大小最大为 10M</div>
  </el-upload>
</template>

<script>
import Cookies from 'js-cookie'
export default {
  name: 'singleUpload',
  props: {
    image: {
      type: Array,
      default: []
    },
    value: {
      type: String,
      default: ''
    }
  },
  data() {
    return {
      imageList: []
    }
  },
  created() {
    this.imageList.push(...this.image)
  },
  watch: {
    image(val) {
      this.imageList = val
    }
  },
  methods: {
    beforeUpload(file) {
      if (file.type !== 'image/jpeg' && file.type !== 'image/png') {
        this.$message.error('上传图片只能是 JPG/PNG 格式!')
        return false
      }

      return true
    },
    onUploadSuccess(response, file, fileList) {
      this.$emit('input', response)
    },
    handleUploadChange(file, fileList) {
      this.imageList = fileList.slice(-1)
    },
    async uploadImg(item) {
      const OSS = require('ali-oss')
      const client = new OSS({
        region: 'oss-cn-hangzhou',
        endpoint: Cookies.get('msk_oss_end_point'),
        accessKeyId: Cookies.get('msk_oss_key'),
        accessKeySecret: Cookies.get('msk_oss_secret'),
        bucket: Cookies.get('msk_oss_bucket')
      })

      const filename = Date.parse(new Date())
      const fileExt = item.file.name.toLowerCase().split('.').splice(-1)
      const newFilename = filename + '-' + Math.floor(Math.random() * Math.floor(999999)) + '.' + fileExt[0]
      const result = await client.put(newFilename, item.file)

      return result.url
    }
  }
}
</script>

<style>
</style>