海康威视H5无插件方式显示WSS协议的视频的笔记

由于要在麒麟桌面系统的浏览器也能显示视频,以前的插件方式就不行了。

一、从官网下载文档和demo

打开官网https://open.hikvision.com/download/5c67f1e2f05948198c909700?type=10

下载H5开发文件和demo

二、放入我的vue2的项目中

把demo中的相关文件复制到我的public的utils目录下,同时在src下的utils目录也放一份h5player.min.js

三、在index.html中引入

四、在显示视频的vue组件中引入

并加入div

html 复制代码
<div id="player" style="width: 100%; height: 700px;"></div>

五、这是我的部分代码片段

注意其中的szBasePath路径要写正确,为相对路径,对应src下的utils里的

bash 复制代码
	   //初始化播放器
	   initPlayer () {
		this.player = new window.JSPlugin({
		  // 需要英文字母开头 必填
		  szId: 'player',
		  // 必填,引用H5player.min.js的js相对路径
		  szBasePath: '../../../utils',
  
		  // 当容器div#play_window有固定宽高时,可不传iWidth和iHeight,窗口大小将自适应容器宽高
		  iWidth: 600,
		  iHeight: 400,
  
		  // 分屏播放,默认最大分屏4*4
		  iMaxSplit: 16,
		  iCurrentSplit: 2,
  
		  // 样式
		  oStyle: {
			border: '#343434',
			borderSelect: '#FFCC00',
			background: '#000'
		  }
		})
	  },
bash 复制代码
/**
	   * 播放
	   */
	  play(index, cameraIndexCode) {
		const _this = this
		let params = {
		  cameraIndexCode: cameraIndexCode,
		  protocol: 'wss'
		}
		let preUrl = ''
		const loading = this.$loading({ lock: true });
		videoApi.getPreviewURL(params).then(res => {
		  if (!res) {
			this.$message.error('获取取流地址失败');
			return;
		  }
		  preUrl = res;
  
		  const param = {
			playURL: preUrl,
			// 1:高级模式  0:普通模式,高级模式支持所以
			mode: 1//1
		  }
		  // 索引默认0
		  if (!index) {
			index = 0
		  }
		  _this.player.JS_Play(preUrl, param, index).then(() => {
			this.curVideoWindowIndex = index
			loading.close();
			console.log('播放成功')
		  },
		  (err) => {
			loading.close();
			console.log('播放失败'+JSON.stringify(err))
		  })
		}).catch((e) => {
			loading.close();
			this.$message.error('未获取到相关信息。'+e.message);
			return '';
		});
	  },
	   /* 回放 */
	   playback(index, cameraIndexCode, beginTime, endTime) {
		let playURL = "";
		let beginStr = this.$moment(beginTime).format('YYYY-MM-DDTHH:mm:ss.SSS[Z]');
		let endStr = this.$moment(endTime).format('YYYY-MM-DDTHH:mm:ss.SSS[Z]');
		let params = {
		  cameraIndexCode: cameraIndexCode,
		  protocol: 'wss',
		  beginTime: beginStr,
		  endTime: endStr
		}
		const loading = this.$loading({ lock: true });
		videoApi.getPlaybackData(params).then(res => {
		  if(!res || !res.url){
			this.$message.error('数据不存在');
			return
		  }
		  playURL = res.url
		  let mode = 1
		  let d1 = this.$moment(beginTime).format('YYYY-MM-DDTHH:mm:ss[Z]');
		  let d2 = this.$moment(endTime).format('YYYY-MM-DDTHH:mm:ss[Z]');
		  this.player.JS_Play(playURL, { playURL, mode }, index, d1, d2).then(
			() => {
			  this.curVideoWindowIndex = index
			  loading.close();
			  console.log('playbackStart success')
			},
			e => { 
			  loading.close();
			  console.error(e) 
			}
		  )
		}).catch((e) => {
			loading.close();
			this.$message.error('未获取到相关信息。'+e.message);
			return '';
		});
	  },

六、后端部分JAVA代码

可先参考下载的JAVA代码

java 复制代码
@Data
public class HaiKangSearchDTO {
	public String cameraIndexCode;
	public String protocol;
	@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'", timezone = "GMT+8")
	@ApiModelProperty("回放查询起始时间")
	public Date beginTime;
	
	@JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd'T'HH:mm:ss.SSS'Z'", timezone = "GMT+8")
	@ApiModelProperty("回放查询结束时间")
	public Date endTime;
}
java 复制代码
//请求回放视频的相关信息
ArtemisConfig config = new ArtemisConfig();
		config.setHost(outerVideoConfig.getIp()+":"+outerVideoConfig.getPort()); // 代理API网关nginx服务器ip端口
		config.setAppKey(outerVideoConfig.getAppkey());
		config.setAppSecret(outerVideoConfig.getSecret());
		final String getCamsApi = ARTEMIS_PATH + "/api/video/v2/cameras/playbackURLs";
		Map<String, String> paramMap = new HashMap<String, String>();
		paramMap.put("cameraIndexCode", dto.getCameraIndexCode());
		paramMap.put("recordLocation", "1");
		paramMap.put("transmode", "1");
		paramMap.put("protocol", dto.getProtocol());
		paramMap.put("beginTime", beginTimeString);
		paramMap.put("endTime", endTimeString);
		String body = JSON.toJSON(paramMap).toString();
		Map<String, String> path = new HashMap<String, String>(2) {
			{
				put("https://", getCamsApi);
			}
		};
		String resultStr = ArtemisHttpUtil.doPostStringArtemis(config, path, body, null, null, "application/json");

七、其它

注意,因为我的系统是https的,所以请求的protocol为wss,如何海康的请求地址是https但却是IP地址,而不是域名形式,则不能显示视频。需要手动在麒麟系统的奇安信浏览器导入海康的证书。

相关推荐
一嘴一个橘子27 分钟前
mybatis - 动态语句、批量注册mapper、分页插件
java
组合缺一28 分钟前
Json Dom 怎么玩转?
java·json·dom·snack4
危险、44 分钟前
一套提升 Spring Boot 项目的高并发、高可用能力的 Cursor 专用提示词
java·spring boot·提示词
kaico20181 小时前
JDK11新特性
java
钊兵1 小时前
java实现GeoJSON地理信息对经纬度点的匹配
java·开发语言
jiayong231 小时前
Tomcat性能优化面试题
java·性能优化·tomcat
秋刀鱼程序编程1 小时前
Java基础入门(五)----面向对象(上)
java·开发语言
纪莫1 小时前
技术面:MySQL篇(InnoDB的锁机制)
java·数据库·java面试⑧股
Remember_9931 小时前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode
Filotimo_2 小时前
在java开发中,cron表达式概念
java·开发语言·数据库