报警上报,即前端设备在检测到事先规定的特殊事件发生时,发送报警到平台端告知平台。平台可以接收到设备上传的外部报警、视频信号丢失报警、遮挡报警和动态检测报警等信息。
TSINGSEE青犀视频EasyCVR平台已经在国标GB28181协议下实现了告警上报功能,现今正处于研究大华SDK报警上报阶段,已具备一定成果,因此和大家分享下。
EasyCVR平台告警上报实现方式为SDK主动连接设备,并向设备订阅报警功能,设备检测到报警事件立即发送给 SDK。
流程说明:
- 完成SDK初始化流程。
- 初始化成功后,调用 CLIENT_LoginEx2 登录设备。
- 调用 CLIENT_SetDVRMessCallBack,设置报警事件回调函数,该接口需在报警订阅之前调用。
- 调用 CLIENT_StartListenEx,向设备订阅报警。订阅成功后,设备上报的报警事件通过 CLIENT_SetDVRMessCallBack 设置的回调函数通知用户。
- 报警上报功能使用完毕后,调用 CLIENT_StopListen,停止向设备订阅报警。
- 调用 CLIENT_Logout,退出设备。
- SDK功能使用完后,调用 CLIENT_Cleanup 释放SDK资源。
示例代码:
代码语言:javascript复制#include <windows.h>
#include <stdio.h>
#include "dhnetsdk.h"
#pragma comment(lib , "dhnetsdk.lib")
static BOOL g_bNetSDKInitFlag = FALSE;
static LLONG g_lLoginHandle = 0L;
static char g_szDevIp[32] = "172.23.2.66";
static WORD g_nPort = 37777; // tcp 连接端口,需与期望登录设备页面 tcp 端口配置一
致
static char g_szUserName[64] = "admin";
static char g_szPasswd[64] = "admin";
static BOOL g_bStartListenFlag = FALSE;
//*************************************************************************
********
// 常用回调集合声明
// 设备断线回调函数
// 不建议在该回调函数中调用 SDK 接口
// 通过 CLIENT_Init 设置该回调函数,当设备出现断线时,SDK 会调用该函数。
void CALLBACK DisConnectFunc(LLONG lLoginID, char *pchDVRIP, LONG nDVRPort,
DWORD dwUser);
// 断线重连成功回调函数
// 不建议在该回调函数中调用 SDK 接口
// 通过 CLIENT_SetAutoReconnect 设置该回调函数,当已断线的设备重连成功时,SDK 会
调用该函数。
void CALLBACK HaveReConnect(LLONG lLoginID, char *pchDVRIP, LONG nDVRPort,
LDWORD dwUser);
133 // 报警事件回调函数
// 不建议在该回调函数中调用 SDK 接口
// 通过 CLIENT_SetDVRMessCallBack 设置该回调函数,当接收到设备上报的报警事件时,
SDK 会调用该函数
BOOL CALLBACK MessCallBack(LONG lCommand, LLONG lLoginID, char *pBuf, DWORD
dwBufLen, char *pchDVRIP, LONG nDVRPort, LDWORD dwUser);
//*************************************************************************
************
void InitTest()
{
// 初始化 SDK
g_bNetSDKInitFlag = CLIENT_Init(DisConnectFunc, 0);
if (FALSE == g_bNetSDKInitFlag)
{
printf("Initialize client SDK fail; n");
return;
}
else
{
printf("Initialize client SDK done; n");
}
// 获取 SDK 版本信息
// 此操作为可选操作
DWORD dwNetSdkVersion = CLIENT_GetSDKVersion();
printf("NetSDK version is [%d]n", dwNetSdkVersion);
// 设置断线重连回调接口,设置过断线重连成功回调函数后,当设备出现断线情况,SDK
内部会自动进行重连操作
// 此操作为可选操作,但建议用户进行设置
CLIENT_SetAutoReconnect(&HaveReConnect, 0);
134 135
// 设置登录超时时间和尝试次数
// 此操作为可选操作
int nWaitTime = 5000; // 登录请求响应超时时间设置为 5s
int nTryTimes = 3; // 登录时尝试建立链接 3 次
CLIENT_SetConnectTime(nWaitTime, nTryTimes);
// 设置更多网络参数,NET_PARAM 的 nWaittime,nConnectTryNum 成员与
CLIENT_SetConnectTime 接口设置的登录设备超时时间和尝试次数意义相同
// 此操作为可选操作
NET_PARAM stuNetParm = {0};
stuNetParm.nConnectTime = 3000; // 登录时尝试建立链接的超时时间
CLIENT_SetNetworkParam(&stuNetParm);
NET_DEVICEINFO_Ex stDevInfoEx = {0};
int nError = 0;
while(0 == g_lLoginHandle)
{
// 登录设备
g_lLoginHandle = CLIENT_LoginEx2(g_szDevIp, g_nPort, g_szUserName,
g_szPasswd, EM_LOGIN_SPEC_CAP_TCP, NULL, &stDevInfoEx, &nError);
if(0 == g_lLoginHandle)
{
// 根据错误码,可以在 dhnetsdk.h 中找到相应的解释,此处打印的是 16 进制,
头文件中是十进制,其中的转换需注意
// 例如:
// #define NET_NOT_SUPPORTED_EC(23) // 当前 SDK 未支持该功能,对应的
错误码为 0x80000017, 23 对应的 16 进制为 0x17
printf("CLIENT_LoginEx2 %s[%d]Failed!Last Error[%x]n" , g_szDevIp ,
g_nPort , CLIENT_GetLastError()); }
else
{
printf("CLIENT_LoginEx2 %s[%d] Successn" , g_szDevIp , g_nPort);
}
// 用户初次登录设备,需要初始化一些数据才能正常实现业务功能,建议登录后等待
一小段时间,具体等待时间因设备而异。
Sleep(1000);
printf("n");
}
}
void RunTest()
{
if (FALSE == g_bNetSDKInitFlag)
{
return;
}
if (0 == g_lLoginHandle)
{
return;
}
// 设置报警事件回调函数
CLIENT_SetDVRMessCallBack(MessCallBack , NULL);
// 向设备订阅报警
if( TRUE == CLIENT_StartListenEx(g_lLoginHandle))
{
g_bStartListenFlag = TRUE;
136 printf("CLIENT_StartListenEx Success!nJust Wait Event....n");
}
else
{
printf("CLIENT_StartListenEx Failed!Last Error[%x]n" ,
CLIENT_GetLastError());
}
}
void EndTest()
{
printf("input any key to quit!n");
getchar();
// 停止向设备订阅报警
if (TRUE == g_bStartListenFlag)
{
if (FALSE == CLIENT_StopListen(g_lLoginHandle))
{
printf("CLIENT_StopListen Failed!Last Error[%x]n",
CLIENT_GetLastError());
}
else
{
g_bStartListenFlag = FALSE;
}
}
// 退出设备
if (0 != g_lLoginHandle)
{
if(FALSE == CLIENT_Logout(g_lLoginHandle))
137 138
{
printf("CLIENT_Logout Failed!Last Error[%x]n",
CLIENT_GetLastError());
}
else
{
g_lLoginHandle = 0;
}
}
// 清理初始化资源
if (TRUE == g_bNetSDKInitFlag)
{
CLIENT_Cleanup();
g_bNetSDKInitFlag = FALSE;
}
return;
}