‘liusuyi’
2023-11-09 092d7c56bb8653075b8f4b27220e69e6bb8e5d37
src/main/java/com/ard/utils/hiksdk/service/impl/FMSGCallBack.java
@@ -54,22 +54,23 @@
        String sTime;//事件时间
        String url = "";//事件图片
        //lCommand是传的报警类型
        //log.debug("报警事件类型:lCommand:" + Integer.toHexString(lCommand));
        log.debug("报警事件类型:lCommand:" + Integer.toHexString(lCommand));
        ArdCameras ardCameras = new ArdCameras();
        ardCameras.setIp(sDeviceIP);
        ardCameras.setPort(wLinkPort);
        IArdCamerasService ardCamerasService = SpringUtils.getBean(IArdCamerasService.class);
        List<ArdCameras> ardCamerasList = ardCamerasService.selectArdCamerasList(ardCameras);
        if (ardCamerasList.size() > 0) {
            ArdCameras camera = ardCamerasService.selectArdCamerasList(ardCameras).get(0);
            switch (lCommand) {
                case HCNetSDK.COMM_ALARM_V30:
                    //log.debug("移动侦测");
                    HCNetSDK.NET_DVR_ALARMINFO_V30 netDvrAlarminfoV30 = new HCNetSDK.NET_DVR_ALARMINFO_V30();
                    netDvrAlarminfoV30.write();
                    Pointer pNDAInfo = netDvrAlarminfoV30.getPointer();
                    pNDAInfo.write(0, pAlarmInfo.getByteArray(0, netDvrAlarminfoV30.size()), 0, netDvrAlarminfoV30.size());
                    netDvrAlarminfoV30.read();
        switch (lCommand) {
            //region 移动侦测、视频丢失、遮挡、IO信号量等报警信息(V3.0以上版本支持的设备)
            case HCNetSDK.COMM_ALARM_V30:
                //region 移动侦测、视频丢失、遮挡、IO信号量等报警信息(V3.0以上版本支持的设备)
                HCNetSDK.NET_DVR_ALARMINFO_V30 netDvrAlarminfoV30 = new HCNetSDK.NET_DVR_ALARMINFO_V30();
                netDvrAlarminfoV30.write();
                Pointer pNDAInfo = netDvrAlarminfoV30.getPointer();
                pNDAInfo.write(0, pAlarmInfo.getByteArray(0, netDvrAlarminfoV30.size()), 0, netDvrAlarminfoV30.size());
                netDvrAlarminfoV30.read();
                if (ardCamerasList.size() > 0) {
                    ArdCameras camera = ardCamerasService.selectArdCamerasList(ardCameras).get(0);
                    switch (netDvrAlarminfoV30.dwAlarmType) {
                        case 3:
                            info = new CameraEventInfo();
@@ -90,21 +91,26 @@
                            publishMqtt(info);
                            break;
                    }
                case HCNetSDK.COMM_ALARM_RULE:
                    //log.debug("行为分析信息报警信息上报");
                    //region 行为分析信息
                    HCNetSDK.NET_VCA_RULE_ALARM strVcaAlarm = new HCNetSDK.NET_VCA_RULE_ALARM();
                    strVcaAlarm.write();
                    Pointer pVCAInfo = strVcaAlarm.getPointer();
                    pVCAInfo.write(0, pAlarmInfo.getByteArray(0, strVcaAlarm.size()), 0, strVcaAlarm.size());
                    strVcaAlarm.read();
                    Integer ruleID = Integer.valueOf(strVcaAlarm.struRuleInfo.byRuleID);
                    sTime = DateUtils.parseTime(strVcaAlarm.dwAbsTime);//事件时间
                    String ipaddr = new String(strVcaAlarm.struDevInfo.struDevIP.sIpV4).trim();//设备ip
                    Integer channel = Integer.valueOf(strVcaAlarm.struDevInfo.byChannel);//通道
                    info = new CameraEventInfo();
                    info.setAlarmName("人员行为分析");
                    info.setAlarmTime(sTime);
                }
                //endregion
                break;
            case HCNetSDK.COMM_ALARM_RULE:
                //log.debug("行为分析信息报警信息上报");
                //region 异常行为识别信息
                HCNetSDK.NET_VCA_RULE_ALARM strVcaAlarm = new HCNetSDK.NET_VCA_RULE_ALARM();
                strVcaAlarm.write();
                Pointer pVCAInfo = strVcaAlarm.getPointer();
                pVCAInfo.write(0, pAlarmInfo.getByteArray(0, strVcaAlarm.size()), 0, strVcaAlarm.size());
                strVcaAlarm.read();
                Integer ruleID = Integer.valueOf(strVcaAlarm.struRuleInfo.byRuleID);
                sTime = DateUtils.parseTime(strVcaAlarm.dwAbsTime);//事件时间
                String ipaddr = new String(strVcaAlarm.struDevInfo.struDevIP.sIpV4).trim();//设备ip
                Integer channel = Integer.valueOf(strVcaAlarm.struDevInfo.byChannel);//通道
                info = new CameraEventInfo();
                info.setAlarmName("人员行为分析");
                info.setAlarmTime(sTime);
                if (ardCamerasList.size() > 0) {
                    ArdCameras camera = ardCamerasService.selectArdCamerasList(ardCameras).get(0);
                    info.setCameraName(camera.getName());
                    info.setCameraId(camera.getId());
                    info.setCameraIp(camera.getIp());
@@ -171,217 +177,218 @@
                            // log.debug("未知行为事件类型:" + strVcaAlarm.struRuleInfo.wEventTypeEx);
                            break;
                    }
                    //endregion
                    break;
                case HCNetSDK.COMM_UPLOAD_FACESNAP_RESULT:
                    //log.debug("人脸检测事件上报(暂不解析)");
                    break;
                case HCNetSDK.COMM_GISINFO_UPLOAD:
                    //log.debug("GPS报警信息上报(暂不解析)");
                    break;
                case HCNetSDK.COMM_ALARMHOST_CID_ALARM:
                    //log.debug("报警主机CID报告报警上报");
                    //region 报警主机报警处理
                    ArdEquipExternal ardEquipExternal = new ArdEquipExternal();
                    ardEquipExternal.setIp(sDeviceIP);
                    ardEquipExternal.setPort(wLinkPort);
                    IArdEquipExternalService ardEquipExternalService = SpringUtils.getBean(IArdEquipExternalService.class);
                    ardEquipExternal = ardEquipExternalService.selectArdEquipExternal(ardEquipExternal);
                }
                //endregion
                break;
            case HCNetSDK.COMM_UPLOAD_FACESNAP_RESULT:
                //log.debug("人脸检测事件上报(暂不解析)");
                break;
            case HCNetSDK.COMM_GISINFO_UPLOAD:
                //log.debug("GPS报警信息上报(暂不解析)");
                break;
            case HCNetSDK.COMM_ALARMHOST_CID_ALARM:
                log.debug("报警主机CID报告报警上报");
                //region 报警主机报警处理
                ArdEquipExternal ardEquipExternal = new ArdEquipExternal();
                ardEquipExternal.setIp(sDeviceIP);
                ardEquipExternal.setPort(wLinkPort);
                IArdEquipExternalService ardEquipExternalService = SpringUtils.getBean(IArdEquipExternalService.class);
                ardEquipExternal = ardEquipExternalService.selectArdEquipExternal(ardEquipExternal);
                    HCNetSDK.NET_DVR_CID_ALARM netDvrCidAlarm = new HCNetSDK.NET_DVR_CID_ALARM();
                    netDvrCidAlarm.write();
                    Pointer pCIDInfo = netDvrCidAlarm.getPointer();
                    pCIDInfo.write(0, pAlarmInfo.getByteArray(0, netDvrCidAlarm.size()), 0, netDvrCidAlarm.size());
                    netDvrCidAlarm.read();
                    //CID事件名
                    String sCIDCode = ByteUtils.bytesToStringZh(netDvrCidAlarm.sCIDCode);//CID事件名
                    //CID事件名
                    //String sCIDDescribe = ByteUtils.bytesToStringZh(netDvrCidAlarm.sCIDDescribe);//CID事件名
                    int position = ByteUtils.findIndexOfDoubleZero(netDvrCidAlarm.sCIDDescribe);
                    String sCIDDescribe;
                    if (position != -1) {
                        byte[] result = new byte[position];
                        System.arraycopy(netDvrCidAlarm.sCIDDescribe, 0, result, 0, position);
                        sCIDDescribe = ByteUtils.bytesToStringZh(result);
                    } else {
                        sCIDDescribe = ByteUtils.bytesToStringZh(netDvrCidAlarm.sCIDDescribe);
                    }
                    //触发报警的时间点
                    String struTriggerTime = DateUtils.convertDate(parseAlarmTime(netDvrCidAlarm.struTriggerTime), "yyyy-M-d H:m:s");
                    //上传报警的时间点
                    String struUploadTime = DateUtils.convertDate(parseAlarmTime(netDvrCidAlarm.struUploadTime), "yyyy-M-d H:m:s");
                    //报告类型
                    String byReportType = "";
                    switch (netDvrCidAlarm.byReportType) {
                        case 1:
                            byReportType = "防区报警";
                            break;
                        case 2:
                            byReportType = "视频报警";
                            break;
                        case 3:
                            byReportType = "软防区报警";
                            break;
                        case 4:
                            byReportType = "挟持报警";
                            break;
                        case 5:
                            byReportType = "防拆报警 ";
                            break;
                        case 6:
                            byReportType = "操作报告 ";
                            break;
                        case 7:
                            byReportType = "异常报告 ";
                            break;
                    }
                    //子系统号
                    Integer bySubSysNo = Integer.valueOf(netDvrCidAlarm.bySubSysNo);
                    //防区号 起始0
                    Integer wDefenceNo = Integer.valueOf(netDvrCidAlarm.wDefenceNo);
                    //防区名称
                    String wDefenceName = "";
                    if (!bySubSysNo.equals(-1)) {
                        CameraCmd cmd = new CameraCmd();
                        cmd.setCameraId(ardEquipExternal.getId());
                        cmd.setWZoneIndex(wDefenceNo);
                        wDefenceName = HikClientUtil.getDefenseZoneName(cmd);
                    }
                    if (sCIDDescribe.contains("恢复")) {
                        return true;
                    }
                    ExternalAlarmEventInfo externalAlarmEventInfo = new ExternalAlarmEventInfo();
                    externalAlarmEventInfo.setAlarmId(sCIDCode);
                    externalAlarmEventInfo.setAlarmName(sCIDDescribe);
                    externalAlarmEventInfo.setDefenseId((wDefenceNo + 1));
                    externalAlarmEventInfo.setDefenseName(wDefenceName);
                    externalAlarmEventInfo.setSubSysNo(bySubSysNo);
                    externalAlarmEventInfo.setAlarmType(byReportType);
                    externalAlarmEventInfo.setAlarmTime(struTriggerTime);
                    externalAlarmEventInfo.setAlarmHostId(ardEquipExternal.getId());
                    publishMqtt(externalAlarmEventInfo);
                    //endregion
                    break;
                case HCNetSDK.COMM_ALARM_ACS:
                    //region 门禁主机报警处理
                    ArdEquipExternal accessControlHost = new ArdEquipExternal();
                    accessControlHost.setIp(sDeviceIP);
                    accessControlHost.setPort(wLinkPort);
                    ardEquipExternalService = SpringUtils.getBean(IArdEquipExternalService.class);
                    accessControlHost = ardEquipExternalService.selectArdEquipExternal(accessControlHost);
                    HCNetSDK.NET_DVR_ACS_ALARM_INFO strACSInfo = new HCNetSDK.NET_DVR_ACS_ALARM_INFO();
                    strACSInfo.write();
                    Pointer acsInfo = strACSInfo.getPointer();
                    acsInfo.write(0, pAlarmInfo.getByteArray(0, strACSInfo.size()), 0, strACSInfo.size());
                    strACSInfo.read();
                    int dwMajor = strACSInfo.dwMajor;
                    if (dwMajor != 5) {
                        //只获取事件
                        // log.debug("非事件报警数据上报(暂不解析)");
                HCNetSDK.NET_DVR_CID_ALARM netDvrCidAlarm = new HCNetSDK.NET_DVR_CID_ALARM();
                netDvrCidAlarm.write();
                Pointer pCIDInfo = netDvrCidAlarm.getPointer();
                pCIDInfo.write(0, pAlarmInfo.getByteArray(0, netDvrCidAlarm.size()), 0, netDvrCidAlarm.size());
                netDvrCidAlarm.read();
                //CID事件名
                String sCIDCode = ByteUtils.bytesToStringZh(netDvrCidAlarm.sCIDCode);//CID事件名
                //CID事件名
                //String sCIDDescribe = ByteUtils.bytesToStringZh(netDvrCidAlarm.sCIDDescribe);//CID事件名
                int position = ByteUtils.findIndexOfDoubleZero(netDvrCidAlarm.sCIDDescribe);
                String sCIDDescribe;
                if (position != -1) {
                    byte[] result = new byte[position];
                    System.arraycopy(netDvrCidAlarm.sCIDDescribe, 0, result, 0, position);
                    sCIDDescribe = ByteUtils.bytesToStringZh(result);
                } else {
                    sCIDDescribe = ByteUtils.bytesToStringZh(netDvrCidAlarm.sCIDDescribe);
                }
                //触发报警的时间点
                String struTriggerTime = DateUtils.convertDate(parseAlarmTime(netDvrCidAlarm.struTriggerTime), "yyyy-M-d H:m:s");
                //上传报警的时间点
                String struUploadTime = DateUtils.convertDate(parseAlarmTime(netDvrCidAlarm.struUploadTime), "yyyy-M-d H:m:s");
                //报告类型
                String byReportType = "";
                switch (netDvrCidAlarm.byReportType) {
                    case 1:
                        byReportType = "防区报警";
                        break;
                    }
                    int dwMinor = strACSInfo.dwMinor;
                    if (dwMinor != 80 && dwMinor != 104) {
                        //只解析真人检测失败和人脸抓拍失败的次类型事件
                    case 2:
                        byReportType = "视频报警";
                        break;
                    }
                    String alarmType = "";
                    switch (dwMinor) {
                        case 104:
                            alarmType = "真人检测失败";
                            break;
                        case 80:
                            alarmType = "人脸抓拍失败";
                            break;
                    }
                    log.debug("门禁主机报警上传:" + alarmType);
                    String alarmTime = DateUtils.convertDate(parseAlarmTime(strACSInfo.struTime), "yyyy-M-d H:m:s");
                    case 3:
                        byReportType = "软防区报警";
                        break;
                    case 4:
                        byReportType = "挟持报警";
                        break;
                    case 5:
                        byReportType = "防拆报警 ";
                        break;
                    case 6:
                        byReportType = "操作报告 ";
                        break;
                    case 7:
                        byReportType = "异常报告 ";
                        break;
                }
                //子系统号
                Integer bySubSysNo = Integer.valueOf(netDvrCidAlarm.bySubSysNo);
                //防区号 起始0
                Integer wDefenceNo = Integer.valueOf(netDvrCidAlarm.wDefenceNo);
                //防区名称
                String wDefenceName = "";
                if (!bySubSysNo.equals(-1)) {
                    CameraCmd cmd = new CameraCmd();
                    cmd.setCameraId(ardEquipExternal.getId());
                    cmd.setWZoneIndex(wDefenceNo);
                    wDefenceName = HikClientUtil.getDefenseZoneName(cmd);
                }
                if (sCIDDescribe.contains("恢复")) {
                    return true;
                }
                    //事件图片处理
                    int dwPicDataLen = strACSInfo.dwPicDataLen;
                    if (dwPicDataLen > 0) {
                        try {
                            //将字节写入文件
                            long offset = 0;
                            ByteBuffer buffers = strACSInfo.pPicData.getByteBuffer(offset, strACSInfo.dwPicDataLen);
                            byte[] bytes = new byte[strACSInfo.dwPicDataLen];
                            buffers.rewind();
                            buffers.get(bytes);
                            InputStream input = new ByteArrayInputStream(bytes);
                            String bucketName = "pic";
                            String objectName = "alarm/" + IdUtils.simpleUUID() + ".jpeg";
                            boolean uploadObject = MinioUtil.uploadObject(bucketName, objectName, input, input.available(), "image/JPEG");
                            if (uploadObject) {
                                url = MinioUtil.getBucketObjectUrl(bucketName, objectName);
                                //log.debug("上传文件成功!" + url);
                            }
                        } catch (Exception e) {
                            log.error("图片保存失败");
                ExternalAlarmEventInfo externalAlarmEventInfo = new ExternalAlarmEventInfo();
                externalAlarmEventInfo.setAlarmId(sCIDCode);
                externalAlarmEventInfo.setAlarmName(sCIDDescribe);
                externalAlarmEventInfo.setDefenseId((wDefenceNo + 1));
                externalAlarmEventInfo.setDefenseName(wDefenceName);
                externalAlarmEventInfo.setSubSysNo(bySubSysNo);
                externalAlarmEventInfo.setAlarmType(byReportType);
                externalAlarmEventInfo.setAlarmTime(struTriggerTime);
                externalAlarmEventInfo.setAlarmHostId(ardEquipExternal.getId());
                publishMqtt(externalAlarmEventInfo);
                //endregion
                break;
            case HCNetSDK.COMM_ALARM_ACS:
                log.debug("门禁主机报警上报");
                //region 门禁主机报警处理
                ArdEquipExternal accessControlHost = new ArdEquipExternal();
                accessControlHost.setIp(sDeviceIP);
                accessControlHost.setPort(wLinkPort);
                ardEquipExternalService = SpringUtils.getBean(IArdEquipExternalService.class);
                accessControlHost = ardEquipExternalService.selectArdEquipExternal(accessControlHost);
                HCNetSDK.NET_DVR_ACS_ALARM_INFO strACSInfo = new HCNetSDK.NET_DVR_ACS_ALARM_INFO();
                strACSInfo.write();
                Pointer acsInfo = strACSInfo.getPointer();
                acsInfo.write(0, pAlarmInfo.getByteArray(0, strACSInfo.size()), 0, strACSInfo.size());
                strACSInfo.read();
                int dwMajor = strACSInfo.dwMajor;
                if (dwMajor != 5) {
                    //只获取事件
                    // log.debug("非事件报警数据上报(暂不解析)");
                    break;
                }
                int dwMinor = strACSInfo.dwMinor;
                if (dwMinor != 80 && dwMinor != 104) {
                    //只解析真人检测失败和人脸抓拍失败的次类型事件
                    break;
                }
                String alarmType = "";
                switch (dwMinor) {
                    case 104:
                        alarmType = "真人检测失败";
                        break;
                    case 80:
                        alarmType = "人脸抓拍失败";
                        break;
                }
                log.debug("门禁主机报警上传:" + alarmType);
                String alarmTime = DateUtils.convertDate(parseAlarmTime(strACSInfo.struTime), "yyyy-M-d H:m:s");
                //事件图片处理
                int dwPicDataLen = strACSInfo.dwPicDataLen;
                if (dwPicDataLen > 0) {
                    try {
                        //将字节写入文件
                        long offset = 0;
                        ByteBuffer buffers = strACSInfo.pPicData.getByteBuffer(offset, strACSInfo.dwPicDataLen);
                        byte[] bytes = new byte[strACSInfo.dwPicDataLen];
                        buffers.rewind();
                        buffers.get(bytes);
                        InputStream input = new ByteArrayInputStream(bytes);
                        String bucketName = "pic";
                        String objectName = "alarm/" + IdUtils.simpleUUID() + ".jpeg";
                        boolean uploadObject = MinioUtil.uploadObject(bucketName, objectName, input, input.available(), "image/JPEG");
                        if (uploadObject) {
                            url = MinioUtil.getBucketObjectUrl(bucketName, objectName);
                            //log.debug("上传文件成功!" + url);
                        }
                    } catch (Exception e) {
                        log.error("图片保存失败");
                    }
                    HCNetSDK.NET_DVR_ACS_EVENT_INFO struAcsEventInfo = strACSInfo.struAcsEventInfo;
                    int byType = struAcsEventInfo.byType;
                    String defenseType = "";
                    switch (byType) {
                        case 0:
                            defenseType = "即时防区";
                            break;
                        case 1:
                            defenseType = "24小时防区";
                            break;
                        case 2:
                            defenseType = "延时防区";
                            break;
                        case 3:
                            defenseType = "内部防区";
                            break;
                        case 4:
                            defenseType = "钥匙防区";
                            break;
                        case 5:
                            defenseType = "火警防区";
                            break;
                        case 6:
                            defenseType = "周界防区";
                            break;
                        case 7:
                            defenseType = "24小时无声防区";
                            break;
                        case 8:
                            defenseType = "24小时辅助防区";
                            break;
                        case 9:
                            defenseType = "24小时震动防区";
                            break;
                        case 10:
                            defenseType = "门禁紧急开门防区";
                            break;
                        case 11:
                            defenseType = "门禁紧急关门防区";
                            break;
                        default:
                            defenseType = "无";
                            break;
                    }
                    AccessControlHostEventInfo accessControlHostEventInfo = new AccessControlHostEventInfo();
                    accessControlHostEventInfo.setSerialNo(struAcsEventInfo.dwSerialNo);
                    accessControlHostEventInfo.setAlarmType(alarmType);
                    accessControlHostEventInfo.setDoorNo(struAcsEventInfo.dwDoorNo);
                    accessControlHostEventInfo.setDefenseType(defenseType);
                    accessControlHostEventInfo.setAlarmTime(alarmTime);
                    accessControlHostEventInfo.setPicUrl(url);
                    accessControlHostEventInfo.setAcsId(accessControlHost.getId());
                    publishMqtt(accessControlHostEventInfo);
                    //endregion
                    break;
                default:
                    // log.debug("未知报警事件类型:lCommand:" + Integer.toHexString(lCommand));
                    break;
                }
                HCNetSDK.NET_DVR_ACS_EVENT_INFO struAcsEventInfo = strACSInfo.struAcsEventInfo;
                int byType = struAcsEventInfo.byType;
                String defenseType = "";
                switch (byType) {
                    case 0:
                        defenseType = "即时防区";
                        break;
                    case 1:
                        defenseType = "24小时防区";
                        break;
                    case 2:
                        defenseType = "延时防区";
                        break;
                    case 3:
                        defenseType = "内部防区";
                        break;
                    case 4:
                        defenseType = "钥匙防区";
                        break;
                    case 5:
                        defenseType = "火警防区";
                        break;
                    case 6:
                        defenseType = "周界防区";
                        break;
                    case 7:
                        defenseType = "24小时无声防区";
                        break;
                    case 8:
                        defenseType = "24小时辅助防区";
                        break;
                    case 9:
                        defenseType = "24小时震动防区";
                        break;
                    case 10:
                        defenseType = "门禁紧急开门防区";
                        break;
                    case 11:
                        defenseType = "门禁紧急关门防区";
                        break;
                    default:
                        defenseType = "无";
                        break;
                }
                AccessControlHostEventInfo accessControlHostEventInfo = new AccessControlHostEventInfo();
                accessControlHostEventInfo.setSerialNo(struAcsEventInfo.dwSerialNo);
                accessControlHostEventInfo.setAlarmType(alarmType);
                accessControlHostEventInfo.setDoorNo(struAcsEventInfo.dwDoorNo);
                accessControlHostEventInfo.setDefenseType(defenseType);
                accessControlHostEventInfo.setAlarmTime(alarmTime);
                accessControlHostEventInfo.setPicUrl(url);
                accessControlHostEventInfo.setAcsId(accessControlHost.getId());
                publishMqtt(accessControlHostEventInfo);
                //endregion
                break;
            default:
                log.debug("未知报警事件类型:lCommand:" + Integer.toHexString(lCommand));
                break;
            }
        }
        return true;
    }