Web端和移动端接入萤石云平台的视频数据
前言
因为项目需要在Web和App上展示实时视频流信息,所以之前做项目时尝试了很多方法。有用vlc插件播放的(由于使用到了插件,所以安卓App、微信小程序都不能显示视频,最后也放弃了),也有使用海康威视Web开发包开发的。但是最简单的是直接在Web端或App上接入萤石云平台的视频流(不能看历史数据,只能看实时的视频,使用萤石云平台的云存储功能需要收费)。使用平台提供的服务的前提是要购买萤石云或者海康威视的设备。以下内容是我将萤石云平台官方文档和自己实践过程中遇到的问题的总结。官方文档地址:https://open.ys7.com/doc/zh/book/index/live_proto.html
使用海康威视设备在Web端显示实时视频 https://blog.csdn.net/qq_38289815/article/details/84779753
海康威视Web端视频开发 https://blog.csdn.net/qq_38289815/article/details/92428396
萤石云摄像头Http接口云台控制开发 https://blog.csdn.net/qq_38289815/article/details/94288310
1. 直播接入指南
直播地址是萤石开放平台为用户提供的最简易视频接入方式,不需要学习复杂的流媒体知识,不需要过硬的开发技术,只需要一个摄像头,一个开发者账号即可实现远程观看直播视频。
1.1. 直播地址获取
(1)注册成为开发者后登录开放平台官网(此账号还可以登录"萤石云视频"App),进入开发者服务-我的资源-我的设备中添加设备(需将设备连上网后进行添加),添加成功刷新页面可以看到设备信息,如下图:
(2)可以下载一个"萤石云视频"App,注册账号后登录就可以添加设备了,一般买到的萤石云摄像头底座都有一个二维码,用App扫描添加就可以了。还有另一种方法是点击上一个图片中的"添加设备",填写相应的数据。App添加更为方便,而且在App上添加完设备后就可以直接查看到视频流了。
(3)添加完设备后,平台还不会提供服务,需要在"我的应用"中获取测试AccessToken以及填写相应信息后才能使用服务。
(4)完成上一步后,就可以在使用直播的服务了。App添加更为方便,而且在App上添加完设备后就可以直接查看到视频流了。此时要在App中将"视频加密"关闭,不然视频无法使用直播服务。设备添加完成后,可在"萤石云视频"App中进行设置。
(5)选择一个设备点击直播地址,进入直播地址设置页面,不用担心关闭加密会造成可能的危险,直播地址的安全可以设置有效期来控制,后面安全防盗方面会进行相应的介绍。关闭加密后就可以看到你的设备已经生成相应的直播地址了,如下图:
(6)进入直播地址后可以获取如下链接:
1.2. 简单区分
HLS适用于移动端使用,可用微信直接打开,也可集成H5页面嵌入到微信小程序或者微信公众号中。
RTMP适用于PC网页端使用,可用flash或者ckplayer等播放器嵌入网页的方式播放,较HLS延迟小,更稳定。
注意:使用前先进行HLS播放测试,确认视频可正常播放后再进行使用,无法播放的地址会展示错误提示,根据错误提示进行调整,若调整无法恢复可在工单系统中提问咨询。
1.3. H5使用方法——HLS
萤石云平台提供了可直接使用的H5页面,可快速生成设备HLS地址的H5直播页面,启用H5播放页进行简单配置即可使用,如下图:
该H5页面仅用于移动端展示,不能用于PC端网页使用,但可以在PC网页F12中看到源码,有需要可以参考源码实现自己的H5页面。
注意:集成H5页面的过程中请在真机(手机)上测试验证,不支持模拟器调试。
1.4. Web使用方法——RTMP
Web页面集成需要用户先准备一个服务器,搭建网页后将视频按照下面介绍的方法接入即可播放。
下载UIKit JavaScript上传服务器后解压,然后进行如下页面配置
首先引入ezuikit.js
<script src="/ezuikit.js"></script>页面创建一个video标签 [若设置autoplay属性则默认自动播放]
<video id="myPlayer" poster="[这里可以填入封面图片URL]" controls playsInline webkit-playsinline [autoplay]><source src="[这里填入从开放平台官网获取到的RTMP协议URL]" type="" />
</video>再进行初始化
<script>var player = new EZUIPlayer('myPlayer');
</script>
简单的视频接入已经实现了,运行Web服务器即可体验。完整示例可查看UIKit JavaScript。
播放器更多操作可以深入学习ckplayer配置(http://www.ckplayer.com/manualx/13.html)
若需要集成多个视频创建多个播放器即可实现,但需要注意的是集成多个播放器需要注意单个播放器的长宽比例限制最小为{width: 400px;height: 300px;}(chrome浏览器限制),小于这个大小时自动播放会失效。
1.5. 微信公众号使用方法——HLS
在微信公众号中嵌入H5页面的方式来播放视频,参考H5使用方法生成H5页面后,拷贝地址到微信公众号的跳转页面地址即可,具体操作如下:
可关注萤石开放平台公众号(微信号ez_open)进行体验。
1.6. 微信小程序使用方法——HLS
小程序中的视频只支持以小程序的原生组件接入,所以H5页面的代码并不适用于小程序,小程序只能使用video组件播放。
<view><video>[这里填入从开放平台官网获取到的HLS协议URL]</video>
</view>
完整示例可见Video组件介绍(https://developers.weixin.qq.com/miniprogram/dev/component/video.html)
注意:集成小程序的过程中请在真机(手机)上测试验证,不支持模拟器调试。
1.7. 安全防盗
直播地址的特点是易于分享,但由于是标准协议,无法用于加密设备。所以萤石云平台提供了针对HLS直播地址的防盗方法(RTMP暂不支持)。这个方法需要用户在服务器上生产带有效期的直播地址,定时刷新供前端页面使用。使用该接口可以让用户只获取到指定5分钟、10分钟、1小时等有效的直播地址,过期后该地址将无法打开视频,需要向商家获取新的地址。接口调用逻辑:开通直播功能(新设备需开通直播)——获取指定有效期的直播地址(https://open.ys7.com/doc/zh/book/index/address.html)
FAQ:
1. 直播地址是否可以进行录像回放?
答:目前只能用于设备画面的直播,回放技术正在预研中,敬请期待。
2. 播放测试报451不支持的码流类型?
答:有如下两种情况可能报该错误;1)部分海康摄像头没有子码流,所以无法播放流畅的视频,详情可在海康官网查看指定型号的介绍。2)海康NVR的通道关联失败,无法通过NVR取到指定通道的视频数据,一般为IPC与NVR断开连接导致。
3. 播放测试报452、454、501、503、544错误?
答:这类错误码为网络错误,建议刷新重试,检查设备与播放端网络情况。
4. 直播报非H264编码类型或有视频但没有声音?
答:直播的视频编码类型仅支持H264,音频编码类型只支持AAC,可以修改设备配置来实现直播。编码格式可以在萤石工作室-设备管理-局域网搜索到的设备-高级设置-图像-视音频编码类型中修改-保存。注意:主码流/子码流/对应通道下的编码类型都需要修改。
App播放HLS流视频效果演示:
在项目中添加如下代码代码:
<script src="https://open.ys7.com/sdk/js/1.3/ezuikit.js"></script>
<video id="myPlayer" poster="" controls playsInline webkit-playsinline autoplay><source src="RTMP的链接" type="" /> <source src="HLS的连接" type="application/x-mpegURL" />
</video>
//根据需求选择链接<script>var player = new EZUIPlayer('myPlayer');player.on('error', function(){console.log('error');});player.on('play', function(){console.log('play');});player.on('pause', function(){console.log('pause');});
</script>以上代码可以在Web端使用,也可以在移动端使用。
Web端和移动端接入萤石云平台的视频数据相关推荐
- Web端接入萤石云平台的视频数据
前言 因为项目需要在Web和App上展示实时视频流信息,所以之前做项目时尝试了很多方法.有用vlc插件播放的(由于使用到了插件,所以安卓App.微信小程序都不能显示视频,最后也放弃了),也有使用海康威 ...
- 微信小程序中播放海康萤石云HLS '.m3u8'视频 video标签
微信小程序中播放海康萤石云HLS '.m3u8'视频 video标签 前言 萤石云开放平台 微信开发者工具 前言 因为项目需要在微信小程序上展示实时视频流信息,以下内容是我将萤石云平台官方文档和自己实 ...
- 萤石云平台接入_前端接入监控视频
简介 在可视化平台的展示中,监控视频可能是不可或缺的一部分.由于屏幕的尺寸限制,监控视频在可视化平台中占比不大,但是对于设计到实物的企业来说,监控视频在可视化平台中的展现是必不可少的一部分. 海康威视 ...
- 智慧社区系统、智能社区、智能照明、楼控系统、web端管理系统+智慧楼宇管理系统、可视化大屏园区数据
智慧社区系统.智能社区.智能照明.楼控系统.web端管理系统+智慧楼宇管理系统.可视化大屏园区数据+楼控系统(智能照明.电梯系统)+安防系统(视频监控.防盗报警/门禁管理/电子巡更/消防报警)+设备台 ...
- 油烟在线监控系统云平台 油烟环保监测云平台 油烟大数据平台
摘要:餐饮业油烟是大气中挥发性有机物(VOCS)和 PM10 的主要来源之一.近年来随着环保治理的加强,中央.省市区不断强化餐饮经营商全覆盖安装油烟净化器工作,但在监管上仍存在一些问题和漏洞. (1) ...
- 阿里云IOT设备数据接入 (从阿里云IOT云平台获取设备数据)
从阿里云IOT云平台获取设备数据 前言: 这篇文档主要讲述的就是当设备的数据发送到物联网套件之后,用户的服务端如何获取设备 的数据. 通过阅读阿里云IoT文档,我们了解到队列中消 ...
- 移动云平台OneNet之数据可视化View连接本地MySQL数据库
记录Windows下移动云平台OneNet之数据可视化View连接本地MySQL数据库 项目相关背景:最近在写一个关于智慧电网的项目系统,最终发现自己设计的UI实在太丑,于是想利用云平台开放的可视化v ...
- vue技术分享ppt_胡中南:Web端GIS技术新进展 | GTC专题论坛报告(视频+PPT+速记)
点击图片上方蓝色字体"慧天地"即可订阅 文章转载自微信公众号GIS软件技术大会,版权归原作者及刊载媒体所有. 在GTC 2020『GIS基础软件新技术论坛』上,超图研究院副院长胡中 ...
- 关于调用萤石云ezuikit-js的视频对象销毁
相信能看到我这篇文章的都是被折磨的不成样子的同学,我只用一行代码就能解决这个问题. document.getElementById('video-container1').innerHTML= &qu ...
- Python Web中REST API使用示例——基于云平台+云服务打造自己的在线翻译工具
做为一个程序员可能在学习技术,了解行业新动态,解决问题时经常需要阅读英文的内容:而像我这样的英文小白就只能借助翻译工具才能理解个大概:不禁经常感慨,英文对学习计算机相关知识太重要了!最近发现IBM的云 ...
最新文章
- http 缓存分为客户端缓存和服务端缓存
- Zigbee系列(概览)
- WatchOS系统开发大全(4)-WatchApp生命周期
- 牛客 - 交换(思维+找循环节)
- webstrom 中 plugins error 设置里 Languages Frameworks里面没有JavaScript?
- Java新手造假_老板居然让我在Java项目中“造假”
- phpstud如何安装mysql新版_MySQL_图解MySQL数据库的安装和操作,一、MySQL下载与安装 1、 - phpStudy...
- 中年高校教师、行政人员的21个特征!
- Azure系列1.1.2 —— 用于 IntelliJ 的 Azure 工具包的登录说明
- mysql8以上的连接配置
- Cocos2d-x音乐和音效概述
- 阶段1 语言基础+高级_1-3-Java语言高级_06-File类与IO流_04 IO字节流_7_字节输出流的续写和换行...
- 《认知盈余:自由时间的力量》读书笔记
- css font-family 字体及各大主流网站对比
- Linux安装杀毒软件clamav
- 阿里巴巴助攻腾讯破6.2亿微商传销第一大案!涉案公众号粉丝2400
- 计算机类电影制作专业大学,大学本科计算机专业 电影资讯类APP的设计与实现毕业论文.doc...
- 04_Python简答题
- java中浏览器电脑的分辨率_关于移动端适配,你必须要知道的
- matlab变步长龙格库塔法,matlab龙格库塔法变步长龙格库塔法.doc-资源下载在线文库www.lddoc.cn...