• EasyNVR网页摄像机无插件H5、谷歌Chrome直播方案-Onvif(二)使用Onvif协议进行设备RTSP地址获取


    背景介绍

    EasyNVR最大的优势就是兼容性,通过RTSP协议接入传统网络摄像机、NVR、编码器等,使用RTSP协议接入能兼容市面上绝大多数网络摄像机等源设备,最大程度的提高整体方案的硬件设备的兼容性,有效的避免采用各个硬件厂家SDK定制的繁琐以及不通用问题;上一篇我们详细说明如何发现网内Onvif设备,还有如何探测特定设备的信息EasyNVR-Onvif(一)使用Onvif协议进行设备发现以及指定设备信息探测

    本文主要说明如何进行很重要的信息获取,就是设备的流地址(RTSP地址)

    1.流程

    要获取设备的RTSP地址,首先需要获取到设备的Device Service Address,也就是上一篇提到的。如果需要获取更进一步的信息,还需要知道此设备的用户名和密码,不然无法进行下一步操作。

    • 获取设备能力Capabilities

    获取设备的能力,并且可以获取到Media和PTZ的URL,使用这两个URL可以进行流和PTZ操作

    
        _tds__GetCapabilities* capabilities = soap_new__tds__GetCapabilities(proxyDevice, -1);    
         
        tt__CapabilityCategory* category = new tt__CapabilityCategory;
        capabilities->Category = category;
        *(capabilities->Category) = tt__CapabilityCategory__All;
        _tds__GetCapabilitiesResponse* response = soap_new__tds__GetCapabilitiesResponse(proxyDevice, -1);
        if (SOAP_OK == proxyDevice->GetCapabilities(capabilities, response))
        {
    	    if (response->Capabilities)
    	{
    		//Media URI: response->Capabilities->Media->XAddr;
    		//PTZ URI: response->Capabilities->PTZ->XAddr;
    	   }
        }
    
    
    • 获取Media Profile

    使用上一步获取到的Media URI获取设备的Media Profile

    
        _trt__GetProfiles* getProfiles = soap_new__trt__GetProfiles(proxyMedia, -1);
        _trt__GetProfilesResponse* response = soap_new__trt__GetProfilesResponse(proxyMedia, -1);
        if (SOAP_OK == proxyMedia->GetProfiles(getProfiles, response))
        {
    	    int size = response->__sizeProfiles;
    	    for (int i = 0; i < size; ++i)
    	    {
    		  if (response->Profiles[i])
    		  {
    			//Media Profile Token: response->Profiles[i]->token;
    			//一般设备包含多个Profile Token,包含主码流、子码流、第三码流
    		 }
    	   }
        }
    
    
    • 获取Media Uri

    使用获取的Media URI和Media Profile Token获取对应的Media Uri,也就是RTSP地址

    
        MediaBindingProxy* proxyMedia = new MediaBindingProxy;
        proxyMedia->soap_endpoint = mediaUrl.c_str();
        _trt__GetStreamUri* getStreamUri = soap_new__trt__GetStreamUri(proxyMedia, -1);
        tt__StreamSetup* streamSetup = soap_new_tt__StreamSetup(proxyMedia, -1);
        getStreamUri->StreamSetup = streamSetup;
        getStreamUri->StreamSetup->Stream = tt__StreamType__RTP_Unicast;
        tt__Transport* transport = soap_new_tt__Transport(proxyMedia, -1);
        getStreamUri->StreamSetup->Transport = transport;
        getStreamUri->StreamSetup->Transport->Protocol = tt__TransportProtocol__RTSP;
        _trt__GetStreamUriResponse* response = soap_new__trt__GetStreamUriResponse(proxyMedia, -1);
    
        if (!profile.empty())
        {
    	    getStreamUri->ProfileToken = const_cast<char*>(profile.c_str());
    	    if (security(proxyMedia, username, password))
    	    {
    		     if (proxyMedia->GetStreamUri(getStreamUri, response) == SOAP_OK)
    		    {
    			    //RTSP地址: response->MediaUri->Uri
    		    }
    	    }
        }
    

    获取到RTSP地址就可以进行拉流操作了

    专业团队

    为了保障我们的服务器正常稳定运作,EasyNVR有专业的运维(售前支撑、商务咨询、售后维护)团队,随时对客户各种突发情况快速响应处理,保证互联网直播的顺利进行。我们也希望实现“0延时”,但理想丰满,现实骨感。每一个完美的直播背后都需要设备、网络、并发量等流程配合完成,正所谓“蝴蝶效应”,任何一个小环节都会对直播延时产生影响,EasyNVR团队要做的就是不断完善开发互联网直播系统,保证直播的低延时、稳定性,同时视频播放高清流畅。
    专业团队

    EasyNVR安防摄像机网页流媒体服务

    EasyNVR是一款拥有完整、自主、可控知识产权,同时又能够具备软硬一体功能的安防互联网化流媒体服务器,能够通过简单的网络摄像机通道配置,将传统监控行业里面的高清网络摄像机IP Camera、NVR等具有RTSP、Onvif协议输出的设备接入到EasyNVR,EasyNVR能够将这些视频源的音视频数据进行拉取,转换为RTMP/HLS,进行全平台终端H5直播(Web、Android、iOS),并且EasyNVR能够将视频源的直播数据对接到第三方CDN网络,实现互联网级别的直播分发。详情可访问EasyNVR官网:http://www.easynvr.com
    EasyNVR应用场景

    智慧城市

    EasyNVR应用场景

    经典案例
  • 相关阅读:
    PHP后门新玩法:一款猥琐的PHP后门分析
    中国菜刀批量导出数据
    渗透测试:反弹与转发小结
    怎样用Java自制优秀的图片验证码?这样!
    6条 Tips 为你照亮 GitHub 寻宝之路
    如何搭建一个“不可告人的”私人专属网盘?教程拿去
    6个炫酷又好用的 Python 工具,个个都很奔放呀
    20个Java练手项目,献给嗜学如狂的人
    如何自己动手写一个搜索引擎?我是一份害羞的教程🙈
    GitHub上个最有意思的项目合集(技术清单系列)
  • 原文地址:https://www.cnblogs.com/babosa/p/11123972.html
Copyright © 2020-2023  润新知