vue 上傳文件到 阿里云OSS,并獲取上傳進度

1.首先,安裝阿里的包

npm install ali-oss

初始化一下配置,傳的參數(shù)data從后臺獲取

const OSS = require('ali-oss')

export function client(data) {
    //后端提供數(shù)據(jù)
  return new OSS({
    region: data.region,  //oss-cn-shenzhen.aliyuncs.com
    accessKeyId: data.accessKeyId,
    accessKeySecret: data.accessKeySecret,
    bucket: data.bucket
  })
}

2.使用element-ui的Upload作為上傳組件,http-request 來綁定自定義上傳的方法Upload,action寫為空。 :before-upload="beforeUpload" 表示在上傳前做的事情,綁定了方法beforeUpload,我們可以在這個方法里獲取所需要的一些信息,比如簽名等等

<el-upload
      :http-request="Upload"
      :data="dataObj" 
      :multiple="false"
      :show-file-list="false"
      :before-upload="beforeUpload" //在上傳前做的事情
      class="image-uploader"
      drag
      action=""
    >
      <i class="el-icon-upload"/>
      <div class="el-upload__text">將圖片拖到此處,或<em>點擊上傳</em></div>
    </el-upload>

data 例子如下

data() {
      return {
        tempUrl: '', //存上傳后的圖片url
        dataObj: {}, //存簽名信息
        baseAli: 'oss-cn-shenzhen.aliyuncs.com', //后面連接圖片url用的,根據(jù)自己aili OSS 配制修改
      progress:0//進度條
      }
    },

3.methods
從后臺獲取第一步所需的數(shù)據(jù)


  beforeUpload() {
        return new Promise((resolve, reject) => {
//從后臺獲取第一步所需的數(shù)據(jù)
          getAliToken().then(response => {
            this.dataObj = response.data
            resolve(true)
          }).catch(err => {
            console.log(err)
            reject(false)
          })
        })
      },

上傳方法

Upload(file) {
        const that = this
        //判斷擴展名
        const tmpcnt = file.file.name.lastIndexOf(".")
        const exname = file.file.name.substring(tmpcnt + 1)
        const names = ['jpg', 'jpeg', 'webp', 'png','bmp']
        if(names.indexOf(exname)< 0 ){
          this.$message.error("不支持的格式!")
          return
        }
        async function multipartUpload () {

          const fileName = that.name + file.file.uid
          //定義唯一的文件名,打印出來的uid其實就是時間戳
          //client 是第一步中的 client
          client(that.dataObj).multipartUpload(fileName, file.file,
            {
              progress:function (p) { //獲取進度條的值
                console.log(p)
                that.progress = p*100
              },

            }).then(
            result => {
              //下面是如果對返回結(jié)果再進行處理,根據(jù)項目需要
              // console.log(result)
              that.tempUrl = 'http://'+result.bucket+'.'+that.baseAli+ '/' + result.name

            }).catch(err => {
            console.log("err:",err)
          })
        }
        multipartUpload ()


      },

至此,上傳完成

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容