极乐门资源网 Design By www.ioogu.com
起因
根据需求要实现一个视频上传功能,之前采用七牛云上传,小点视频没问题,大体积视频比如600M左右,再考虑到网速等其他原因就会花费半个小时左右。
后来分析到不仅要考虑上传时间的问题,更重要的是要考虑用户使用4G 网络的情况,考虑用户的流量,线上的视频,不能不做压缩转码,就放到页面上,视频不是图片,不能甩到 cdn 上就行了。 要考虑视频大小,pc 移动端适配,转码,还有防盗版等问题。
最终决定使用腾讯云上传视频,我的项目是web端上传,参考以下链接
官网链接: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
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后请求后端的视频详情接口,最终播放返回的视频地址即可。
极乐门资源网 Design By www.ioogu.com
极乐门资源网
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
极乐门资源网 Design By www.ioogu.com
暂无vue结合el-upload实现腾讯云视频上传功能的评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 第五街的士高《印度激情版》3CD [WAV+CUE][2.4G]
- 三国志8重制版哪个武将智力高 三国志8重制版智力武将排行一览
- 三国志8重制版哪个武将好 三国志8重制版武将排行一览
- 三国志8重制版武将图像怎么保存 三国志8重制版武将图像设置方法
- 何方.1990-我不是那种人【林杰唱片】【WAV+CUE】
- 张惠妹.1999-妹力新世纪2CD【丰华】【WAV+CUE】
- 邓丽欣.2006-FANTASY【金牌大风】【WAV+CUE】
- 饭制《黑神话》蜘蛛四妹手办
- 《燕云十六声》回应跑路:年内公测版本完成95%
- 网友发现国内版《双城之战》第二季有删减:亲亲环节没了!
- 邓丽君2024-《漫步人生路》头版限量编号MQA-UHQCD[WAV+CUE]
- SergeProkofievplaysProkofiev[Dutton][FLAC+CUE]
- 永恒英文金曲精选4《TheBestOfEverlastingFavouritesVol.4》[WAV+CUE]
- 群星《国风超有戏 第9期》[320K/MP3][13.63MB]
- 群星《国风超有戏 第9期》[FLAC/分轨][72.56MB]