Vue集成阿里云点播实现视频上传

实现方式有多种,如下是我的实现方式:

一、下载点播插件,在 public 下的 index.html 中引入阿里云点播需要的 js 插件,js 文件最好放在 cdn 上,,这里以放在 public 文件夹下的 static 文件夹中为例:

javascript 复制代码
<script src="/static/aliyun-upload-sdk-1.5.6/lib/es6-promise.min.js"></script>
<script src="/static/aliyun-upload-sdk-1.5.6/lib/aliyun-oss-sdk-6.17.1.min.js"></script>
<script src="/static/aliyun-upload-sdk-1.5.6/aliyun-upload-sdk-1.5.6.min.js"></script>

二、封装阿里云点播方法

javascript 复制代码
import axios from 'axios'

function createUplader(self) {
  // 声明AliyunUpload.Vod初始化回调
  const uploader = new window.AliyunUpload.Vod({
    userId: '122',
    partSize: 1048576,
    parallel: 5,
    retryCount: 3,
    retryDuration: 2,
    region: 'cn-shanghai',
    enableUploadProgress: true, // 是否上报上传日志到点播,默认为true
    localCheckpoint: true, // 此参数是禁用服务端缓存
    // 添加文件成功
    addFileSuccess: function (uploadInfo) {
      console.log('addFileSuccess:', uploadInfo)
    },
    // 初始化上传实例,开始上传
    onUploadstarted: function (uploadInfo) {
      console.log('onUploadstarted:', uploadInfo)
      // 获取上传凭证 sts token
      axios.get('你的获取上传凭证的api url').then(({ data }) => {
        const accessKeyId = data.accessKeyId
        const accessKeySecret = data.accessKeySecret
        const secretToken = data.securityToken
        uploader.setSTSToken(uploadInfo, accessKeyId, accessKeySecret, secretToken) // 设置STS Token
      })
    },
    // 文件上传成功
    onUploadSucceed: function (uploadInfo) {
      console.log('onUploadSucceed:', uploadInfo, self)
      // 在这里通过回调拿到阿里云返回的上传成功的数据
      self.getFileData(uploadInfo)
    },
    // 文件上传失败
    onUploadFailed: function (uploadInfo) {
      console.log('onUploadFailed:', uploadInfo)
      self.$message.warning('文件上传失败')
    },
    // 取消文件上传
    onUploadCanceled: function (uploadInfo, code, message) {
      console.log('onUploadCanceled: ', uploadInfo, code, message)
    },
    // 文件上传进度,单位:字节
    onUploadProgress: function (uploadInfo, totalSize, loadedPercent) {
      console.log('onUploadProgress:', uploadInfo, totalSize, loadedPercent)
    },
    // 上传STS Token失效
    onUploadTokenExpired: function () {
      console.log('onUploadTokenExpired:上传文件超时')
      axios.get('你的获取上传凭证的api url').then(({ data }) => {
        const accessKeyId = data.accessKeyId
        const accessKeySecret = data.accessKeySecret
        const secretToken = data.securityToken
        uploader.resumeUploadWithSTSToken(accessKeyId, accessKeySecret, secretToken) // 更新STS Token重新上传
      })
      self.$message.success('上传文件超时,正在重新上传')
    },
    // 全部文件上传结束
    onUploadEnd: function (uploadInfo) {
      console.log(uploadInfo, 'onUploadEnd: uploaded all the files')
      self.$message.success('上传成功!')
    }
  })
  return uploader
}

export default function videoChange(file) {
  this.uploader = createUplader(this)
  const paramData = {
    'Vod': {
        'Title': file.name, // 设置阿里云视频控制台Name为文件名
    }
  }
  // 添加上传文件
  this.uploader.addFile(file, null, null, null, JSON.stringify(paramData))
  this.uploader.startUpload() // 开始上传
}

三、页面中使用

javascript 复制代码
<template>
  <a-upload
    :customRequest="handleChange"
    :file-list="fileList"
  >
    <a-button> <a-icon type="upload" /> 上传 </a-button>
  </a-upload>
</template>

<script>
import videoChange from '@/utils/upload-file-to-sts.js'
export default {
  data() {
    return {
      fileList: [], // 已经上传的文件列表
    }
  },
  mounted() {},
  methods: {
    getFileData(res) {
      this.fileList = this.fileList.concat(res)
      this.$emit('input', this.fileList)
    },
    /** 自定义上传事件 */
    async handleChange(info) {
      console.log(info)
      videoChange.call(this, info.file)
    }
  }
}
</script>
相关推荐
小飞大王666几秒前
从零手写 React:深度解析 Fiber 架构与 Hooks 实现
前端·react.js·架构
不甜情歌11 分钟前
JS 异步:Event-Loop+async/await
前端
程序员库里12 分钟前
AI协同写作应用-TipTap基础功能
前端·javascript·面试
程序员阿峰13 分钟前
【JavaScript面试题-算法与数据结构】手写一个 LRU(最近最少使用)缓存类,支持 `get` 和 `put` 操作,要求时间复杂度 O(1)
前端·javascript·面试
im_AMBER14 分钟前
AJAX vs Fetch API:Promise 与异步 JavaScript 怎么用?
前端·javascript·面试
用户97514707513614 分钟前
关于通过react使用hooks进行数据状态处理
前端
GISer_Jing15 分钟前
React:从SPA到全场景渲染的进化之路
前端·react.js·前端框架
Highcharts.js27 分钟前
Highcharts React v4 迁移指南(上):核心变更解析与升级收益
前端·javascript·react.js·react·数据可视化·highcharts·v4迁移
SuniaWang32 分钟前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题八:《RAG 系统安全与权限管理:企业级数据保护方案》
java·前端·人工智能·spring boot·后端·spring·架构
菌菌的快乐生活40 分钟前
在 WPS 中设置 “第一章”“第二章” 这类一级编号标题自动跳转至新页面
前端·javascript·wps