vue + el-upload 实现腾讯云视频上传功能

5,924 阅读2分钟

起因

根据需求要实现一个视频上传功能,之前采用七牛云上传,小点视频没问题,大体积视频比如600M左右,再考虑到网速等其他原因就会花费半个小时左右。

后来分析到不仅要考虑上传时间的问题,更重要的是要考虑用户使用4G 网络的情况,考虑用户的流量,线上的视频,不能不做压缩转码,就放到页面上,视频不是图片,不能甩到 cdn 上就行了。 要考虑视频大小,pc 移动端适配,转码,还有防盗版等问题。

最终决定使用腾讯云上传视频,我的项目是web端上传,参考以下链接

官网链接:cloud.tencent.com/document/pr…

在项目中的使用

项目使用vue.js + element-ui el-upload组件

  • 引入sdk:

    npm install vod-js-sdk-v6

    import TcVod from 'vod-js-sdk-v6'

  • html代码

        //上传
     <el-upload
        ref="upload"
        action="filename" 
        :http-request="httpRequest"
        :show-file-list="false">
        <i v-if="videoFlag == false" class="el-icon-plus avatar-uploader-icon"></i>
      </el-upload>
      
      // 进度条
      <el-progress
          v-if="videoFlag"
          type="circle"
          :percentage="videoUploadPercent"
        ></el-progress>
    
    • action:上传地址,必填,但我们使用http-request,填任意字符串即可,没有实际意义。
    • http-request:覆盖默认上传行为,我们这里就需要自定义上传行为
    • percentage:进度条进度
  • js代码

    methods:{
     // 视频-自定义地址
       httpRequest(file){
        const _this = this
         // 限制视频格式
          if (["video/mp4", "video/quicktime"].indexOf(file.file.type) == -1) {
            this.$message.error("视频格式有误,上传失败");
            return false;
          }
           // 限制视频小于700M
          const isLt10M = file.file.size / 1024 / 1024 < 700;
          if (!isLt10M) {
            this.$message.error("请上传MP4、MOV格式且不超过700MB的视频哦!");
            return false;
          }
           // 显示进度条从0开始
            _this.videoFlag = true
            this.videoUploadPercent=0
          // 获取视频签名
            const getSignature = async function(){
              return await getuploadsignature({  //这里就是发axios请求
                video_type:'operating_activity'  // 参数是和后台定义的,不需要可以不写
              }).then(res => {
                 return res
              })
        }
    
       // 前文中所述的获取上传签名的函数
        const tcVod = new TcVod({
          getSignature:getSignature
         })
        const uploader = tcVod.upload({
          mediaFile: file.file // 这里腾讯云需要获取到file文件里的name,根据你file结构进行填写
        })
        this.uploaderG = uploader // 定义全局用于取消上传
    
        // 进度
        uploader.on('media_progress', function(info) {
            _this.videoUploadPercent = parseInt(info.percent * 100);
        })
    
        // 上传成功
        uploader.done().then((doneResult) => {
            _this.videoFlag = false // 关闭进度条
            _this.videoForm.Video = doneResult.fileId // 存储fileId
            // 这里发请求给后端进行转码操作
            const data = {
              file_id:doneResult.fileId, // 腾讯云file_id
              video_type:'operating_activity', // 视频类型
              video_name:'', // 视频名称
              video_url: doneResult.video && doneResult.video.url?doneResult.video.url:'',// 视频地址
            }
            // 腾讯视频转码
            videoProcedure(data)
            .then(res => {
            }).catch(err => {
              console.log(err)
            })
        }).catch( (err) => {
          console.log(err)
        })
    }
    }
    

    转码需要一定的时间,视频体积越大转码时间越长。

    表单提交时将fileId值传给后端,等需要预览视频时,获取fileId后请求后端的视频详情接口,最终播放返回的视频地址即可。