阿里云VOD 视频点播(一)、nuxt视频上传,视频播放

news/2025/1/13 2:55:32/

一,nuxt视频上传,视频播放

(1).nuxt视频上传,封装的组件,我开发的时候有eslint校验下面代码有一些相关的注释不用管

<template><div class="container"><div class="upload"><div><div class="filebox"><input id="fileUpload" type="file" class="filebtn" @change="fileChange($event)"><div class="flletit">选择视频</div></div><div class="filetitle">{{ fileTitle }}</div><label class="status">上传状态: <span>{{ statusText }}</span></label></div><div class="upload-type"><el-button slot="trigger" size="small" type="primary" :disabled="uploadDisabled" @click="authUpload">开始上传</el-button><el-button style="margin-left: 10px;" size="small" type="danger" :disabled="pauseDisabled" @click="pauseUpload">暂停</el-button><el-button slot="trigger" size="small" type="success" :disabled="resumeDisabled" @click="resumeUpload">恢复上传</el-button></div><el-progress :text-inside="true" :stroke-width="15" :percentage="authProgress" :status="authProgress == 100 ?'success':'text'" /></div></div>
</template>
<script>
export default {data() {return {vid: '',fileTitle: '',timeout: '',partSize: '',parallel: '',retryCount: '',retryDuration: '',region: 'cn-shanghai',userId: '输入阿里云账号ID',file: null,authProgress: 0,uploadDisabled: true,resumeDisabled: true,pauseDisabled: true,uploader: null,statusText: ''}},methods: {emitEventVod() {// eslint-disable-next-line no-consoleconsole.log('-----1-----')this.authProgress = 0this.fileTitle = ''this.statusText = ''this.pauseDisabled = truethis.resumeDisabled = truethis.uploadDisabled = true},fileChange(e) {this.file = e.target.files[0]if (!this.file) {this.$message.error('请先选择需要上传的文件!')return}if (this.file.type !== 'video/mp4') {this.$message.error('请选择.mp4文件!')return}this.fileTitle = this.file.nameconst userData = '{"Vod":{}}'if (this.uploader) {this.uploader.stopUpload()this.authProgress = 0this.statusText = ''}this.uploader = this.createUploader()// eslint-disable-next-line no-consoleconsole.log(userData)this.uploader.addFile(this.file, null, null, null, userData)this.uploadDisabled = falsethis.pauseDisabled = truethis.resumeDisabled = true},authUpload() {// 然后调用 startUpload 方法, 开始上传if (this.uploader !== null) {this.uploader.startUpload()this.uploadDisabled = truethis.pauseDisabled = false}},// 暂停上传pauseUpload() {if (this.uploader !== null) {this.uploader.stopUpload()this.resumeDisabled = falsethis.pauseDisabled = true}},// 恢复上传resumeUpload() {if (this.uploader !== null) {this.uploader.startUpload()this.resumeDisabled = truethis.pauseDisabled = false}},createUploader(type) {const self = this// eslint-disable-next-linelet uploader = new AliyunUpload.Vod({timeout: self.timeout || 60000,partSize: self.partSize || 1048576,parallel: self.parallel || 5,retryCount: self.retryCount || 3,retryDuration: self.retryDuration || 2,region: self.region,userId: self.userId,// 添加文件成功addFileSuccess: function (uploadInfo) {self.uploadDisabled = falseself.resumeDisabled = falseself.statusText = '添加文件成功, 等待上传...'// eslint-disable-next-line no-consoleconsole.log('addFileSuccess: ' + uploadInfo.file.name)},// 开始上传onUploadstarted: function (uploadInfo) {// 如果是 UploadAuth 上传方式, 需要调用 uploader.setUploadAuthAndAddress 方法// 如果是 UploadAuth 上传方式, 需要根据 uploadInfo.videoId是否有值,调用点播的不同接口获取uploadauth和uploadAddress// 如果 uploadInfo.videoId 有值,调用刷新视频上传凭证接口,否则调用创建视频上传凭证接口// 注意: 这里是测试 demo 所以直接调用了获取 UploadAuth 的测试接口, 用户在使用时需要判断 uploadInfo.videoId 存在与否从而调用 openApi// 如果 uploadInfo.videoId 存在, 调用 刷新视频上传凭证接口(https://help.aliyun.com/document_detail/55408.html)// 如果 uploadInfo.videoId 不存在,调用 获取视频上传地址和凭证接口(https://help.aliyun.com/document_detail/55407.html)if (!uploadInfo.videoId) {const title = uploadInfo.file.name.substr(0, uploadInfo.file.name.lastIndexOf('.'))self.$axios.get('/api/ossFile/createUploadVideo', { params: { title: title, fileName: uploadInfo.file.name } }).then(({ data: res }) => {if (res.code !== 0) {return self.$message.error(res.msg)}const uploadAuth = res.data.UploadAuthconst uploadAddress = res.data.UploadAddressconst videoId = res.data.VideoIdself.vid = res.data.VideoIduploader.setUploadAuthAndAddress(uploadInfo, uploadAuth, uploadAddress, videoId)})self.statusText = '文件开始上传...'// eslint-disable-next-line no-consoleconsole.log('onUploadStarted:' + uploadInfo.file.name + ', endpoint:' + uploadInfo.endpoint + ', bucket:' + uploadInfo.bucket + ', object:' + uploadInfo.object)} else {// 如果videoId有值,根据videoId刷新上传凭证self.$axios.get('/api/ossFile/refreshUploadVideo', { params: { videoId: uploadInfo.videoId } }).then(({ data: res }) => {if (res.code !== 0) {return self.$message.error(res.msg)}const uploadAuth = res.data.UploadAuthconst uploadAddress = res.data.UploadAddressconst videoId = res.data.VideoIdself.vid = res.data.VideoIduploader.setUploadAuthAndAddress(uploadInfo, uploadAuth, uploadAddress, videoId)})}},// 文件上传成功onUploadSucceed: function (uploadInfo) {// eslint-disable-next-line no-consoleconsole.log('onUploadSucceed: ' + uploadInfo.file.name + ', endpoint:' + uploadInfo.endpoint + ', bucket:' + uploadInfo.bucket + ', object:' + uploadInfo.object)self.statusText = '文件上传成功!'},// 文件上传失败onUploadFailed: function (uploadInfo, code, message) {// eslint-disable-next-line no-consoleconsole.log('onUploadFailed: file:' + uploadInfo.file.name + ',code:' + code + ', message:' + message)self.statusText = '文件上传失败!'},// 取消文件上传onUploadCanceled: function (uploadInfo, code, message) {// eslint-disable-next-line no-consoleconsole.log('Canceled file: ' + uploadInfo.file.name + ', code: ' + code + ', message:' + message)self.statusText = '文件已暂停上传'},// 文件上传进度,单位:字节, 可以在这个函数中拿到上传进度并显示在页面上onUploadProgress: function (uploadInfo, totalSize, progress) {// eslint-disable-next-line no-consoleconsole.log('onUploadProgress:file:' + uploadInfo.file.name + ', fileSize:' + totalSize + ', percent:' + Math.ceil(progress * 100) + '%')const progressPercent = Math.ceil(progress * 100)self.authProgress = progressPercentself.statusText = '文件上传中...'},// 上传凭证超时onUploadTokenExpired: function (uploadInfo) {// 上传大文件超时, 如果是上传方式一即根据 UploadAuth 上传时// 需要根据 uploadInfo.videoId 调用刷新视频上传凭证接口(https://help.aliyun.com/document_detail/55408.html)重新获取 UploadAuth// 然后调用 resumeUploadWithAuth 方法, 这里是测试接口, 所以我直接获取了 UploadAuthself.$axios.get('/api/ossFile/refreshUploadVideo', { params: { videoId: uploadInfo.videoId } }).then(({ data: res }) => {if (res.code !== 0) {return self.$message.error(res.msg)}const uploadAuth = res.data.UploadAuthuploader.resumeUploadWithAuth(uploadAuth)// eslint-disable-next-line no-consoleconsole.log('upload expired and resume upload with uploadauth ' + uploadAuth)})self.statusText = '文件超时...'},// 全部文件上传结束onUploadEnd: function (uploadInfo) {// eslint-disable-next-line no-consoleconsole.log('onUploadEnd: uploaded all the files')self.statusText = '文件上传完毕'self.emitEvent(self.vid)}})return uploader},emitEvent(vid) {this.$emit('my-event', vid)}}
}
</script>
<style>.container{text-align: center;line-height: 1;}.upload-type{margin: 15px 0;}.filebox{width: 80px;height: 32px;color: #fff;background-color: #17B3A3;border-color: #17B3A3;position: relative;border-radius: 3px;text-align: center;line-height: 32px;margin: 0 auto;}.filebox .filebtn{
width: 100%;height: 100%;border: none;background: none;position: absolute;left: 0;top: 0;opacity: 0;}.filebox .flletit{width: 100%;height: 100%;}.filetitle{margin: 10px 0;}.status span{color: #FF4C52;}
</style>

(2),nuxt引入阿里提供的上传js文件,添加ssr:false服务端渲染关闭,因为js里面有document,window,服务端渲染会报错undefined

在这里插入图片描述在这里插入图片描述
(3),页面调用封装好的组件,里面涉及到父子组件相互调用,传值

<template><div><upload-vod ref="childVod" @my-event="getMyEvent" /></div>
</template>
<script>
import UploadVod from '../../components/uploadvod'
export default {components: {UploadVod},data() {return {}},created() {this.init()},methods: {init() {const that = thisif (process.client) {that.$nextTick(() => {that.$refs.childVod.emitEventVod()})}},getMyEvent(vid) {// eslint-disable-next-line no-consoleconsole.log('接收的数据--------->' + vid)this.$message({message: '接收的数据---->' + vid,type: 'success'})}}
}
</script>

(4),nuxt视频播放相关,上传根据官方提供的demo修改的,自己封装了组件,引入的也是网络js文件

<template><div :id="playerId" class="prism-player" />
</template><script>
export default {props: {aliplayerSdkPath: {// Aliplayer 代码的路径type: String,default: '//g.alicdn.com/de/prismplayer/2.8.2/aliplayer-min.js'}},data() {return {playerId: 'aliplayer_' + Math.random().toString(36).substr(2),scriptTagStatus: 0,isReload: false,instance: null,vid: '',playauth: '',cover: ''}},created() {this.init()},mounted() {if (window.Aliplayer !== undefined) {// 如果全局对象存在,说明编辑器代码已经初始化完成,直接加载编辑器this.scriptTagStatus = 2this.initAliplayer()} else {// 如果全局对象不存在,说明编辑器代码还没有加载完成,需要加载编辑器代码this.insertScriptTag()}},methods: {async init() {const { data } = await this.$axios.get('/api/ossFile/getVideoPlayAuth', { params: { videoId: '903d803f735e47c9aa12ef10721cb9a2' } })// eslint-disable-next-line no-consoleconsole.log('fetch---', data)this.cover = data.data.CoverUrlthis.playauth = data.data.PlayAuththis.vid = data.data.VideoId// eslint-disable-next-lineif (window.Aliplayer !== undefined) {// 如果全局对象存在,说明编辑器代码已经初始化完成,直接加载编辑器this.scriptTagStatus = 2this.initAliplayer()} else {// 如果全局对象不存在,说明编辑器代码还没有加载完成,需要加载编辑器代码this.insertScriptTag()}},insertScriptTag() {const _this = thislet playerScriptTag = document.getElementById('playerScriptTag')// 如果这个tag不存在,则生成相关代码tag以加载代码if (playerScriptTag === null) {playerScriptTag = document.createElement('script')playerScriptTag.type = 'text/javascript'playerScriptTag.src = this.aliplayerSdkPathplayerScriptTag.id = 'playerScriptTag'const s = document.getElementsByTagName('head')[0]s.appendChild(playerScriptTag)}if (playerScriptTag.loaded) {_this.scriptTagStatus++} else {playerScriptTag.addEventListener('load', () => {_this.scriptTagStatus++playerScriptTag.loaded = true_this.initAliplayer()})}_this.initAliplayer()},initAliplayer() {const _this = this// scriptTagStatus 为 2 的时候,说明两个必需引入的 js 文件都已经被引入,且加载完成if (_this.scriptTagStatus === 2 &&(_this.instance === null || _this.reloadPlayer)) {_this.instance && _this.instance.dispose()document.querySelector('#' + _this.playerId).innerHTML = ''// Vue 异步执行 DOM 更新,这样一来代码执行到这里的时候可能 template 里面的 script 标签还没真正创建// 所以,我们只能在 nextTick 里面初始化 Aliplayer_this.$nextTick(() => {// eslint-disable-next-lineconst player = new Aliplayer({'id': _this.playerId,'width': '100%','height': '500px','autoplay': true,'isLive': false,'rePlay': false,'playsinline': true,'preload': true,'controlBarVisibility': 'hover','useH5Prism': true,'vid': _this.vid,'playauth': _this.playauth,'cover': _this.cover}, function (player) {// console.log('123')})})}}}
}
</script>
<style>@import url(//g.alicdn.com/de/prismplayer/2.8.2/skins/default/aliplayer-min.css);
</style>

(5),将组件封装为一个插件js,然后引入js到nuxt中,以为组件里面有document,window,需要关闭ssr服务端渲染
在这里插入图片描述

import Vue from 'vue'
import AliplayerVod from '~/components/VideoPlayVod.vue'Vue.component('ali-aliplayer-vod', AliplayerVod)

关闭ssr,如图
在这里插入图片描述

(6),使用播放的组件

 <ali-aliplayer-vod />

后台java开发的接口代码参照下篇博客,阿里云VOD 视频点播(三)

阿里云VOD 视频点播(三)


http://www.ppmy.cn/news/364631.html

相关文章

阿里云视频点播功能使用

1、开通并且获得密钥和安全密钥 1、开通 1、 2、 3、 4、 2、获得配置参数 1、启用 2、添加转码模组 3、获取AccessKeyId和AccessKey Secret 2、使用 1、下载JavaSDK https://help.aliyun.com/document_detail/51992.htm?spma2c4g.11186623.0.0.67d45d87sMSWRB#topic-195…

阿里云视频点播Demo

前端使用Web端SDK下载&#xff0c;web端先调取自己服务器编写的接口&#xff0c;自己服务器接口中利用服务端接口SDK调取相应的方法 还有个“全局设置”》“回调设置”中设置回调地址&#xff0c;会传过来视频ID,可在视频上传完成后更新视频时长&#xff0c;播放地址等详细信息…

阿里云视频点播介绍

文章目录 1.1 视频服务概述 1.2 视频点播介绍 1.3 功能介绍 1.4 开通服务 1.5 音视频加速服务(了解) 1.6 基本使用 1.6.1 存储管理 1.6.2 设置分类 1.6.3 设置转码模板 1.6.4 上传视频 1.6.5 RAM设置 1.1 视频服务概述 https://help.aliyun.com/ 媒体处理&#xff…

阿里云点播录制,上传,播放使用说明及遇到的坑

项目开发中使用阿里云的点播功能&#xff0c;从中遇到了一堆坑&#xff0c;特写此笔记。希望对使用阿里云点播的伙伴们有所帮助。 一、讲解录制功能 首先赋上阿里云的官方录制文档 https://help.aliyun.com/document_detail/53421.html?spm5176.doc53407.6.680.S2RrZX 在gr…

腾讯云点播播放器TCPlayer开发文档整理edusoho

首先在你的页面中引入css、js文件 <link href"https://imgcache.qq.com/open/qcloud/video/tcplayer/tcplayer.css" rel"stylesheet"><!--如果需要在 Chrome 和 Firefox 等现代浏览器中通过 H5 播放 HLS 格式的视频&#xff0c;需要在 tcplayer.…

阿里云直播、直播录制和点播

近来公司有个直播类的项目&#xff0c;让我调研下阿里云直播&#xff0c;花了3、4天调研结束后&#xff0c;做下笔记&#xff0c;一方面自己日后便于查看&#xff0c;另一方面与大家做个交流&#xff0c;有说的不正确的。欢迎指正。 需求说明&#xff1a;本项目有三个媒体端&a…

腾讯云云直播、云点播

• 前言 • 一、腾讯云云直播、云点播 • 二、智能编排播控系统 • 1.智能编排播控系统之节目编排 • 2.智能编排播控系统之节目制作 • 3.智能编排播控系统之节目播放 • 三、云直播、云点播的安全能力 • 四、云直播、云点播接入简单 前言 智能编排播…

脑机直播 x 赛博驱魔!瑞云专访揭秘胶囊计划国风科幻神作《终极体验》制作幕后...

2021年11月B站发起了一个以扶持国内动画人为愿景与出发点的特别项目《胶囊计划》&#xff0c;以搭建一条全新的道路探索未来行业的方式。Renderbus瑞云渲染一直十分关注国创动画的发展&#xff0c;刚刚结束的2022年小宇宙计划就是由B站主办瑞云协办的青年动画赛事&#xff0c;胶…