起因
起因起因根据需求要实现一个视频上传功能,之前采用七牛云上传,小点视频没问题,大体积视频比如600M左右,再考虑到网速等其他原因就会花费半个小时左右。
后来分析到不仅要考虑上传时间的问题,更重要的是要考虑用户使用4G 网络的情况,考虑用户的流量,线上的视频,不能不做压缩转码,就放到页面上,视频不是图片,不能甩到 cdn 上就行了。 要考虑视频大小,pc 移动端适配,转码,还有防盗版等问题。
最终决定使用腾讯云上传视频,我的项目是web端上传,参考以下链接
官网链接:cloud.tencent.com/document/product/266/9239#.E6.96.AD.E7.82.B9.E7.BB.AD.E4.BC.A0
cloud.tencent.com/document/product/266/9239#.E6.96.AD.E7.82.B9.E7.BB.AD.E4.BC.A0在项目中的使用
在项目中的使用在项目中的使用项目使用vue.js + element-ui el-upload组件引入sdk:
npm install vod-js-sdk-v6
npm install vod-js-sdk-v6
import TcVod from 'vod-js-sdk-v6'
import TcVod from 'vod-js-sdk-v6'html代码


//上传

ref="upload"

action="filename"

:http-request="httpRequest"

:show-file-list="false">




// 进度条

v-if="videoFlag"

type="circle"

:percentage="videoUploadPercent"

>

//上传

ref="upload"

action="filename"

:http-request="httpRequest"

:show-file-list="false">




// 进度条

v-if="videoFlag"

type="circle"

:percentage="videoUploadPercent"

>

action:上传地址,必填,但我们使用http-request,填任意字符串即可,没有实际意义。

http-request:覆盖默认上传行为,我们这里就需要自定义上传行为

percentage:进度条进度
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)

})
}
}
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后请求后端的视频详情接口,最终播放返回的视频地址即可。