ONVIF系列一:ONVIF介绍

        感谢博主OceanStar的学习笔记,ONVIF系列二和系列三中安装操作过程及代码实现参考了这位博主的博客。

        ONVIF系列:

        ONVIF系列一:ONVIF介绍

        ONVIF系列二:Ubuntu安装gSOAP、生成ONVIF代码框架

        ONVIF系列三:ONVIF客户端实现

1、ONVIF是什么

        视频监控领域存在的问题:
        1、厂商定制化:不同厂商的视频设备往往采用不同的通信协议和数据格式,导致设备之间难以互相兼容和集成。例如视频监控都是通过RTSP进行的音视频传输,可是每家厂商摄像头的rtsp地址格式都不一样,这样集成不同厂商之前需要首先知道这家厂商的RTSP地址格式。
        2、功能扩展不统一:尽管RTSP提供了基本的实时流媒体传输功能,但在实际应用中,视频设备可能会扩展一些额外的功能,如事件管理、设备配置等,这些功能的实现方式可能会因厂商而异,导致不同设备之间的功能扩展不统一。
        3、配置和管理不便:在配置和管理摄像头设备的时候,不同厂商会使用不同的应用协议和数据格式,还会对协议和数据格式进行私有化定制,用户可能需要针对不同厂商的设备使用不同的管理工具进行配置和管理,增加了管理的复杂性和成本。

        ONVIF的提出正是为了解决以上问题,ONVIF(Open Network Video Interface Forum)是一个全球性的开放性标准,旨在促进网络视频设备之间的互操作性。它由安迅士、博世、索尼共同创建,在2008年成立,后来一些领先的视频设备制造商、软件开发商和系统集成商也加入了进来。ONVIF致力于推动IP视频监控技术的发展,通过制定统一的网络视频接口标准,促进视频设备之间的互联互通。
        ONVIF协议对设备发现、设备配置、事件、PTZ控制、视频分析、实时流媒体直播功能(RTSP拉流)、搜索、回放、录像录音管理等功能进行了规范。

2、ONVIF Profile:

        ONVIF提供了很多的Profile,每个Profile都定义了一组特定的功能集合,支持ONVIF不需要考虑ONVIF版本只需要保持Profile一致即可互通。

        目前以下几种Profile
        Profile S应用于网络视频系统
        Profile G应用于边缘存储与检索
        Profile C应用于网络电子门禁系统
        Profile Q应用于快速安装
        Profile A应用于更广泛的访问控制配置
        Profile T应用于高级视频流
        IPC摄像头(网络摄像头)有关的主要是Profile S技术规格。

3、ONVIF开发技术框架

        ONVIF规范中设备管理和控制部分所定义的接口均以Web Services的形式提供。每一个支持ONVIF规范的终端设备均须提供与功能相应的Web Service。ONVIF中的其他部分比如音视频流则通过RTSP进行。
ONVIF = 服务端 + 客户端 =(Web Services + RTSP)+ 客户端 = ((WSDL + SOAP) + RTSP) + 客户端


        视频监控中:IPC摄像头就是一个服务端,它对外提供接口服务(Web Services),并使用RTSP协议传输流媒体;客户端通过ONVIF协议规定的Web Services接口可以获取摄像头的RTSP地址,并通过RTSP地址拉取视频流观看视频监控、还可以根据ONVIF协议规范的Web Services接口管理摄像头。

4、Web Services

        网上对Web Services描述的很专业、很绕口,其实Web Services就是对外提供接口的一个http服务,客户端通过调用Web Services提供的接口满足自己的需求,使用的协议都是基于http的,只不过在http请求和响应报文中的负载(payload)不一样(当然我们也可以自己制定私有数据格式,只不过不被业界认可,一般都是内部使用)。

        ONVIF就是把各个功能定义出来,并且把功能对应的Web Services接口固定下来,包括数据格式,参数等,这样就形成了一套规范,各个厂商都遵循这套规范就可以互通了。

        Web Services框架有很多:REST、SOAP、JavaScript、XML-PRC等。不管哪种方式,都是基于的http协议,ONVIF中的Web Service使用的就是SOAP协议。
        SOAP协议 = RPC机制 + HTTP传输协议 + XML数据格式

4.1 RPC

        RPC 全称 Remote Procedure Call——远程过程调用。以前我们写一个函数都是在本地调用就行了。但是在项目中,大多服务都是部署在不同服务器上的分布式系统,服务之间如何调用呢? 答案就是RPC。
        RPC技术简单说就是为了解决远程调用服务的一种技术,使得调用者像调用本地函数一样方便透明,就是让远端服务帮我们干活,并且把结果返回给我们。 下图是客户端调用远端服务的过程:

        1、客户端client发起服务调用请求。

        2、client stub 可以理解成一个代理,会将调用方法、参数按照一定格式进行封装,通过服务提供的地址,发起网络请求。

        3、消息通过网络传输到服务端。

        4、server stub接受来自socket的消息

        5、server stub将消息进行解包、告诉服务端调用的哪个服务,参数是什么

        6、结果返回给server stub。

        7、sever stub把结果进行打包交给socket

        8、socket通过网络传输消息

        9、client slub 从socket拿到消息。

        10、client stub解包消息将结果返回给client。

        在RPC框架中,client调用stub函数就和调用本地函数一样,stub函数会帮我们实现具体细节(http封包-步骤2、socket数据发送-步骤3、socker数据接收-步骤8、http解包-步骤9),这个stub(存根)函数也不需要我们自己写,都有开源框架帮我们实现,不必造轮子。同理server只需要实现server functions实现功能即可,其他的由RPC框架完成。

4.2 SOAP消息格式

        SOAP消息以XML格式编码,一个典型的SOAP消息由以下几部分组成:

        Envelope:定义了SOAP消息的开始和结束点。
        Header   :可选部分,包含一些元数据和扩展信息。
        Body       :包含实际的消息内容。
        Fault       :可选部分,用于描述错误信息。

        SOAP请求:

POST /InStock HTTP/1.1
Host: www.example.org
Content-Type: application/soap+xml; charset=utf-8
Content-Length: nnn<?xml version="1.0"?>
<soap:Envelope
xmlns:soap="http://www.w3.org/2001/12/soap-envelope"
soap:encodingStyle="http://www.w3.org/2001/12/soap-encoding"><soap:Body xmlns:m="http://www.example.org/stock"><m:GetStockPrice><m:StockName>IBM</m:StockName></m:GetStockPrice></soap:Body></soap:Envelope>

        SOAP响应:

HTTP/1.1 200 OK
Content-Type: application/soap+xml; charset=utf-8
Content-Length: nnn<?xml version="1.0"?>
<soap:Envelope
xmlns:soap="http://www.w3.org/2001/12/soap-envelope"
soap:encodingStyle="http://www.w3.org/2001/12/soap-encoding"><soap:Body xmlns:m="http://www.example.org/stock"><m:GetStockPriceResponse><m:Price>34.5</m:Price></m:GetStockPriceResponse></soap:Body></soap:Envelope>

        上面SOAP请求中GetStockPrice就是客户端要调用的远程RPC函数(说是服务也可以),StockName是远程RPC函数参数,SOAP响应中GetStockPriceResponse表示对客户端的响应,也就是客户端调用GetStockPrice RPC函数的响应,SOAP中响应一般是在请求的RPC函数后面加上Response表示响应,Price是GetStockPrice函数的处理结果。由上述过程可见,RPC就是把函数功能放到远端服务器上,由客户端调用,服务器处理完把结果返回,这中间的数据传输都是由HTTP + XML完成的。ONVIF其实就是对服务端(IPC摄像头等)有哪些功能,即RPC函数以及RPC函数参数,还有客户端调用这些RPC函数的http url以及http负载中的xml应该怎么写等进行规范(这些规范都写在了WSDL文档中,将在下面介绍),实现厂商之间互通。

4.3 WSDL

        ONVIF中的SOAP理解了,下面我们来看WSDL。
        WSDL是一种Web服务描述语言,全称Web Services Description Language,是为描述Web服务发布的XML格式。简单来说WSDL就是一个XML格式的说明文档,这个文档描述了Web Services提供哪些接口,参数是什么,前面我们提到RPC框架,帮我们实现了http数据封包解包、数据发送接收,但是这个框架怎么生成,框架应该按照什么样的格式封包解包,这就需要WSDL文档,把WSDL文档扔给框架生成工具就可以帮我们生成Web Services框架(和上面提到的RPC框架是一样的),我们只要写好WSDL文档就有工具帮我造轮子,是不是很方便、很神奇,感谢那些在背后默默付出的攻城狮吧。
        我们的目的是学习ONVIF,不需要我们会怎么写WSDL文档,ONVIF组织已经帮我们写好了,我们只需要会用WSDL文档生成Web Services框架,会看WSDL文档中定义了哪些功能,输入及输出参数是什么即可。

        如下图所示,是ONVIF WSDL文档中定义的获取设备信息接口:

        GetDeviceInformation表示接口名字(RPC函数名字),Description是对接口的描述。

        SOAP Action 是用于标识 SOAP 消息中将要执行的操作的一个 HTTP 头部字段,它在 SOAP 1.1 中被定义为可选的,而在 SOAP 1.2 中则被视为弃用的。通常,SOAP Action 的值是一个 URI,用于唯一地标识 SOAP 消息中的操作。

        Input表示GetDeviceInformation函数参数。

        Output表示输出参数,即GetDeviceInformation返回的结果。

        在ONVIF请求中,会把GetDeviceInformation函数名,GetDeviceInformation函数Input参数都封装到XML中(SOAP格式),在ONVIF响应中会把Output输出结果封装到XML(SOAP格式)中并返回给ONVIF客户端。

        XML格式这里就不介绍了,相关教程有很多,推荐大家学习一下XML中的命名空间,XML命名空间和C++中的命名空间类似,是为了防止不同服务之间的命名冲突,就是在XML元素的前面加上命名空间:,命名空间是在哪里定义的要在属性中声明出来,例如上面SOAP请求中xmlns:m="http://www.example.org/stock"就是声明这个命名空间是在哪里定义的,并给命名空间起一个别名为m,m:GetStockPrice表示调用http://www.example.org/stock里面定义的GetStockPrice,而不是其他地方定义的GetStockPrice,这样就防止了不同服务之前的命名冲突和歧义。

5、ONVIF WSDL文档

        ONVIF接口被划分为不同模块,包括:设备发现、设备管理、设备输入输出服务、图像配置、媒体配置、实时流媒体、接收端配置、显示服务、事件处理、PTZ控制等(不同的Profile包含了不同的模块)。每个模块都提供一个WSDL文档,我们拿到WSDL文档就可以开发了,ONVIF WSDL文档获取地址:https://www.onvif.org/profiles/specifications/
        ONVIF开发中最常用的Web Services框架生成工具是gSOAP,拿到ONVIF的WSDL文档,gSOAP就可以帮我们生成客户端和服务端的代码框架,gSOAP一种跨平台的开源的C/C++软件开发工具包,可以生成C/C++的SOAP Web Service/Client代码,实现XML数据绑定(不需要我们自己封装XML,苦力活都交给gSOAP生成的代码框架完成)。gSOAP支持大多数平台,包括嵌入式系统和小系统(例如嵌入式Symbian,Palm)。gSOAP安装使用将在ONVIF系列二介绍。

        ONVIF的开发技术栈如下图所示:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/696902.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024 年中国大学生程序设计竞赛全国邀请赛(郑州)暨第六届CCPC河南省大学生程序 设计竞赛Problem L. Toxel 与 PCPC II

//sort bug下标 遍历dp. //没修负的bug肯定连续 #include<bits/stdc.h> using namespace std; #define int long long const int n1e611; int a,b,c[n],dp[n]; signed main() {ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);cin>>a>>b;for(int i1;…

升级! 测试萌新Python学习之连通数据库Pymsql增删改及封装(四)

pymysql 数据库概述python对数据库的增删改查pymysql核心操作事务事务操作pymysql工具类封装每日复习ChatGPT的回答 数据库概述 分类 关系型数据库: 安全 如, mysql oracle SQLite…database tables 行列 非关系型数据库: 高效 如, redis mongoDB…数据存储结构多样 键值对…

本来还挺喜欢……

前阵子买了个天空星开发板&#xff0c;到手之后发觉不对劲。 之前我们玩玩开发板都是用的面包板的&#xff0c;就算是ESP那种比较宽的板子用两个面包板拼一下也勉强可以用。 但是天空星它的引脚是分为两组&#xff0c;每组有两排&#xff0c;如果我们还是直接使用面包板的话&a…

【MYSQL】一颗B+树可以保存多少条数据

引言 事万物都有自己的单元体系&#xff0c;若干个小单体组成一个个大的个体。就像拼乐高一样&#xff0c;可以自由组合。所以说&#xff0c;如果能熟悉最小单元&#xff0c;就意味着我们抓住了事物的本事&#xff0c;再复杂的问题也会迎刃而解。 存储单元 存储器范围比较大…

Hystrix服务熔断

服务熔断 熔断机制是应对雪崩效应的一种微服务链路保护机制。当某个微服务不可用或者响应时间太长时&#xff0c; 会进行服务降级&#xff0c;进而熔断该节点微服务的调用&#xff0c;快速返回“错误”的响应信息。当检测到该节点微 服务调用响应正常后恢复调用链路。 在Spri…

软件需求工程习题

1.&#xff08;面谈&#xff09;是需求获取活动中发生的需求工程师和用户间面对面的会见。 2.使用原型法进行需求获取&#xff0c;&#xff08;演化式&#xff09;原型必须具有健壮性&#xff0c;代码质量要从一开始就能达到最终系统的要求 3.利用面谈进行需求获取时&#xf…

自动故障转移

这里询问&#xff0c;你的插槽是从哪里移动过来的&#xff1f; all&#xff1a;代表全部&#xff0c;也就是三个节点各转移一部分具体的id&#xff1a;目标节点的iddone&#xff1a;没有了 这里我们要从7001获取&#xff0c;因此填写7001的id&#xff1a; 填完后&#xff0c;…

一文入门DNS

概述 DNS是一个缩写&#xff0c;可以代表Domain Name System&#xff0c;域名系统&#xff0c;是互联网的一项基础服务。也可以代表Domain Name Server&#xff0c;域名服务器&#xff0c;是进行域名和与之相对应的IP地址相互转换的服务器。DNS协议则是用来将域名转换为IP地址…

半监督的GCN:Semi-Supervised Classification With Graph Convolutional Networks

Semi-Supervised Classification With Graph Convolutional Networks -Theophilus Siameh-2017(2023) 思路 使用可扩展方法对图进行半监督学习,其中CNN应用在图数据上,得到GCN。 这种方法是在图的边的数量上进行线性的缩放模型,并学习包含局部图结构和图节点的几个隐藏层…

Ubuntu22.04怎么安装cuda11.3

环境&#xff1a; WSL2 Ubuntu22.04 问题描述&#xff1a; Ubuntu22.04怎么安装cuda11.3 之前是11.5 解决方案&#xff1a; 在Ubuntu 22.04上安装CUDA 11.3需要一些步骤&#xff0c;因为CUDA 11.3不是为Ubuntu 22.04官方支持的版本。但是&#xff0c;您仍然可以通过以下步…

【玄机平台】应急响应

前言&#xff1a; 感谢玄机平台靶机的提供&#xff0c;让我学到了不少东西 平台题解 &#xff1a; 第一章 应急响应-webshell查杀 1.黑客webshell里面的flag flag{xxxxx-xxxx-xxxx-xxxx-xxxx} ssh连接 下载/var/www/html源码&#xff08;finsehll连直接下&#xff09;压缩丢…

[Kubernetes] sealos 部署 K8s v1.25.0 集群

文章目录 1.sealos 介绍2.操作系统基础配置3.安装部署 K8s4.验证 K8s 集群5.部署测试资源 1.sealos 介绍 Sealos 是一个基于 Kubernetes 内核的云操作系统发行版。它采用云原生方式&#xff0c;摒弃传统的云计算架构&#xff0c;转向以 Kubernetes 为云内核的新架构。这使得企…