一、H5视频播放器开发包地址
1、https://open.hikvision.com/download/5c67f1e2f05948198c909700?type=20
data:image/s3,"s3://crabby-images/050ff/050ff4f7460cce7e3b840aa7a5f8fbd1438c5be4" alt=""
2、内容
data:image/s3,"s3://crabby-images/7e8ae/7e8ae2b83f0f33a2f6e8bd510a4bcdb61d1cc110" alt=""
3、主要用demo里面的文件
data:image/s3,"s3://crabby-images/6292d/6292d82109b5de34427b0d8f536cc8a9342392f2" alt=""
4、demo可以用来测试获取的视频流是不是可以播放,如果用vue开发过,应该有安装的node,在当前页面右键-->在终端中打开
data:image/s3,"s3://crabby-images/28782/2878246a0cc61675a3016b00b7aa25006a2f425b" alt=""
data:image/s3,"s3://crabby-images/7d737/7d7377867389f2b1ff3678533cdaf9d87820d84e" alt=""
(1)两者的不同在于,http.js测试ws格式的视频流,如果生产环境是http的地址,则用这个测试,本地测试可以用这个;https.js用来测试wss格式的视频流,这个对应的是https的生产环境。
(2)下面是打开的测试wss的demo, https://localhost:9091/demo.html(这个链接对应上面)=》http =>ws; https:wss
data:image/s3,"s3://crabby-images/6bea4/6bea4bc1344053d1a89121cf0c9f121c912efbf4" alt=""
5、将demo里面的文件拷贝在vue2项目中,在src同级目录中添加public文件夹,如果有这个文件夹,在下面新建一个文件夹(h5player),将对应的红色框里面的文件拷贝过来
data:image/s3,"s3://crabby-images/085dc/085dc6a3697304e9a6c4f9e2910a3825c9385d73" alt=""
6、在public文件夹下面的index.html文件中加上对插件的引入。同级目录下的js文件
data:image/s3,"s3://crabby-images/3b14a/3b14aad4d362e77d1cbb6f8ed4bb5c9e7c24c021" alt=""
7、查询视频接口;如果获取wss格式的视频流,需要给protocol传wss,获取ws格式的视频流,则传ws
data:image/s3,"s3://crabby-images/51f24/51f246e35f3df6bbb7dbc2dbafc37c4977b7072e" alt=""
8、显示视频位置
<div id="player" class="video" />
9、需要初始化插件相关信息
mounted(){
this.init()
this.initPlayer()
},
// 初始化界面大小,不同尺寸的浏览器调整窗口大小
init() {
// 设置播放容器的宽高并监听窗口大小变化
window.addEventListener('resize', () => {
if( this.player !== null){
this.player.JS_Resize();
}
})
// 初始化播放器
initPlayer(){
this.player = new window.JSPlugin({
// 需要英文字母开头 必填
szId: 'player',
// 必填,引用H5player.min.js的js相对路径,填写的是public下的路径
szBasePath: '/h5player',
openDebug: true,
iMaxSplit: 1,// 我只展示一个视频信息
iCurrentSplit: 1,
// 样式
oStyle: {
border: '#343434',
borderSelect: '#FFCC00',
background: '#000'
}
})
10、展示视频
videoInfo(videoUrl,data){
const _this = this
const param = {
playURL: videoUrl,
// 1:高级模式 0:普通模式,高级模式支持所有
mode: 1
}
// 播放视频
_this.player1.JS_Play(videoUrl, param, 0).then(
() => {
// 由于我只用了一个位置播放,老在左上角展示,所以我重新调整了大小
_this.player1.JS_Resize();},
e => { console.error(e) }
)
// 调整窗口
_this.player1.JS_ArrangeWindow(1).then(
() => {},
e => { console.error(e) }
)
// 插件报错给出提示,要不界面没有反映
_this.player1.JS_SetWindowControlCallback({
// 插件错误回调
pluginErrorHandler(iWindIndex, iErrorCode, oError) {
_this.$publicmethod.showMessage("获取视频信息失败,请您稍后重试!", _this.$publicmethod.ErrorType)
},
});
11、部署生产环境需要有相关的配置,添加nginx的配置信息
(1)修改nginx配置信息
data:image/s3,"s3://crabby-images/43d9c/43d9c4b912f31c137889e7d357e733644c1c8daa" alt=""
(2)在海康的运管中心添加一个线路,提供生产环境的ip以及nginx的端口给海康人员,让他们添加一个线路;海康开发人员都知道!
data:image/s3,"s3://crabby-images/0ffdc/0ffdc5f22470e5994c0dbcad1cd4e038b5ead896" alt=""
(3)将生产环境的证书和密钥上传到海康的运管中心系统,上传证书。添加并下发,下发到所有的系统中,然后重启服务即可!
data:image/s3,"s3://crabby-images/1472a/1472a452b47c069fd58ef6a9c346a307dbcb0744" alt=""
三、问题汇总
1、wss返回的地址是nginx+内网地址和端口,需要在获取到视频地址的接口中,将内网地址替换成外网地址,要不报错!(websocket连接报错502)
2、如果生产环境用的是域名,需要将获取到的地址的ip替换成域名,要不提示不是可信任证书,在console中可以看到ERR_CERT相关报错
data:image/s3,"s3://crabby-images/a924e/a924ec531afeef9606d77fed72bcf7c5ece0dea7" alt=""