欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

基于ONVIF协议的(IPC)客户端程序开发之onvif协议由soap和rtsp协议组成讲解

程序员文章站 2022-03-06 18:44:16
1. 前言 这次「ONVIF协议网络摄像机(IPC)客户端程序开发」专栏。 2. ONVIF背景 网络摄像机是网络设备,需要有通讯协议,早期的网络摄像机硬件提供商都采用私有协...

1. 前言

这次「ONVIF协议网络摄像机(IPC)客户端程序开发」专栏。

2. ONVIF背景

网络摄像机是网络设备,需要有通讯协议,早期的网络摄像机硬件提供商都采用私有协议。

随着视频监控的网络化应用,产业链的分工将越来越细。有些厂商专门做摄像头,有些厂商专门做视频服务器,有些厂商则可能专门做平台等,然后通过集成商进行集成,提供给最终客户。私有协议无法胜任这种产业合作模式,行业标准化的接口由此应运而生。

目前,网络摄像机的标准协议,国际标准上有三大类:ONVIF、PSIA和HDCCTV,国内标准有国标GB/T28181。ONVIF阵营日益壮大,与PSIA、HDCCTV相比,无论是支持厂商的数目、厂商的知名度,还是市场占有率都遥遥领先。ONVIF标准的厂商覆盖芯片、视频前端设备、存储设备、系统平台、智能分析设备、门禁、传感设备等各个安防相关领域。我们说的IPC摄像头只是ONVIF标准里的一个分支而已,可见ONVIF的强大。

ONVIF(Open Network Video Interface Forum,开放型网络视频接口论坛)以公开、开放的原则共同制定开放性行业标准。

从ONVIF官网上可以了解到,为适应各种不同的参与级别,ONVIF提供了不同等级的会员企业资格,其中不乏国内外著名的设备制造商与集成商,国内的华为、海康威视、浙江大华、波粒科技和佳信捷也是ONVIF论坛的高级会员。

3. ONVIF技术框架

ONVIF规范中设备管理和控制部分所定义的接口均以Web Services的形式提供。ONVIF规范涵盖了完全的XML及WSDL的定义。每一个支持ONVIF规范的终端设备均须提供与功能相应的Web Service。服务端与客户端的数据交互采用SOAP协议。ONVIF中的其他部分比如音视频流则通过RTP/RTSP进行。

基于ONVIF协议的(IPC)客户端程序开发之onvif协议由soap和rtsp协议组成讲解

拿IPC摄像头来说,IPC是Web Services服务端,其提供的WEB服务接口需符合ONVIF协议规范(这些接口在ONVIF规定的WSDL文档中),我们开发的客户端通过这些ONVIF规范接口跟IPC通讯,比如:

获取IPC的基本信息(厂家信息、版本信息等);修改IPC的系统日期、时间;修改IPC的网络配置(IP、子网掩码等);获取/修改IPC摄像头的各种参数(视频分辨率、码率、帧率、OSD,云台控制等);

由于SOAP协议不适合传输音视频流,ONVIF规范中的传输音视频流采用的是已经很成熟的RTP/RTSP多媒体传输协议。

简单粗暴的理解:IPC的各种参数获取/配置都是通过ONVIF协议实现,而音视频流多媒体传输采用的是RTP/RTSP协议实现。

4. ONVIF技术规格

ONVIF协议中,有一系列Profile的技术规格。ONVIF之所以引入了Profile的概念,使得终端用户能够更容易区分各个Profile所支持的特性,而无需确定ONVIF技术规格不同版本间的兼容性。截止目前,已经发布的Profile包括Profile S/C/G/A/Q五种。

基于ONVIF协议的(IPC)客户端程序开发之onvif协议由soap和rtsp协议组成讲解

以上截图来源于官网中《ONVIF Profile Feature Overview》文档。从这个图能看出,各个Profile技术规格的发布是有时间先后顺序的,并不是一起发布。Profile S作为profile发布系列中的排头兵,于2011年发布,2016年做了一次修订,Profile C于2013年发布,之后再依次发布Profile G/A/Q。

以下是我对这些Profile的理解:

Profile S:「网络摄像机」的技术规格,包括如何发送音视频流,音视频编码器配置,PTZ控制、中继控制等。Profile C:「门禁控制系统(PACS)设备」的技术规格。Profile G:「视频储存和录像」的技术规格,包括视频储存,搜索,检索,以及媒体播放功能的技术规格。Profile A:「常见的例行门禁控制功能」的技术规范,适用于负责授予和撤销员工凭证、创建和更新计划表,以及对系统内门禁控制权限进行更改的安保人员、接待员或人力资源专员等用户。Profile Q:「传输层安全性(TLS)」的技术规格,该安全通信协议使ONVIF合标设备能够以不受篡改和窃听威胁的方式在网络上与客户通讯。

随着ONVIF的发展,我估计,ONVIF指导委员会(Steering Committee)在未来还会有后续的Profiles发布以规范其他技术规格。

跟IPC摄像头有关的主要是Profile S技术规格。

5. ONVIF接口规范

ONVIF接口被划分为不同模块,包括:设备发现、设备管理、设备输入输出服务、图像配置、媒体配置、实时流媒体、接收端配置、显示服务、事件处理、PTZ控制等。

每个模块的接口都有相对应的WSDL文档进行描述,可以在ONVIF官网「Network Interface Specifications」中查阅

如果想快速浏览ONVIF所有模块的常用接口,请看这里「ONVIF 2.0 Service Operation Index」

注意:这里仅仅是列出常用接口,不是全部接口,每个模块的全部接口需要进入每个模块的WSDL中去看,点击任意一个接口就会自动跳转到对应的WSDL文档链接处。

比如说GetServices接口以上页面没有显示。

想要系统、全面的了解ONVIF的各个模块,可以阅读网上盛传的《ONVIF2.0协议珍藏版》。

现在你对这些ONVIF模块、接口不熟,没关系,跟着我的专栏一步步往下走,以后就会有体会了。

6. 开发流程(不要自己造*)

基于ONVIF协议的(IPC)客户端程序开发之onvif协议由soap和rtsp协议组成讲解

这里先简要的介绍下IPC客户端开发流程,具体怎么操作在专栏后续文章中会陆续展示。ONVIF协议既然是Web Services框架,那就不需要自己造*,ONVIF协议部分由gSOAP工具帮我们自动生成代码框架。

而RTP/RTSP音视频传输部分则采用开源的FFmpge即可,FFmpge在音视频处理方面,那是首屈一指。

基于ONVIF协议的(IPC)客户端程序开发之onvif协议由soap和rtsp协议组成讲解

IPC客户端程序整个开发流程如下图所示:

基于ONVIF协议的(IPC)客户端程序开发之onvif协议由soap和rtsp协议组成讲解