ÎļþÃû´Ó ard-work/src/main/java/com/ruoyi/utils/sdk/hiksdk/service/impl/HikClientServiceImpl.java ÐÞ¸Ä |
| | |
| | | import com.ruoyi.common.utils.file.FileUtils;
|
| | | import com.ruoyi.common.utils.file.MimeTypeUtils;
|
| | | import com.ruoyi.common.utils.uuid.IdUtils;
|
| | | import com.ruoyi.device.camera.domain.CameraCmd;
|
| | | import com.ruoyi.device.camera.service.IArdCamerasService;
|
| | | import com.ruoyi.device.camera.strategy.SdkStrategy; |
| | | import com.ruoyi.device.camera.domain.ArdCameras; |
| | | import com.ruoyi.device.camera.domain.CameraCmd; |
| | | import com.ruoyi.device.channel.domain.ArdChannel;
|
| | | import com.ruoyi.device.channel.service.IArdChannelService;
|
| | | import com.ruoyi.utils.sdk.common.GlobalVariable;
|
| | | import com.ruoyi.device.camera.domain.ArdCameras;
|
| | | import com.ruoyi.utils.sdk.hiksdk.lib.ExceptionCallBack;
|
| | | import com.ruoyi.media.domain.Vtdu;
|
| | | import com.ruoyi.media.service.IVtduService;
|
| | | import com.ruoyi.utils.gis.GisUtil;
|
| | | import com.ruoyi.utils.sdk.hiksdk.lib.HCNetSDK;
|
| | | import com.ruoyi.utils.sdk.hiksdk.service.IHikClientService;
|
| | | import com.ruoyi.utils.sdk.hiksdk.lib.LoginResultCallBack;
|
| | | import com.ruoyi.utils.minio.MinioUtil;
|
| | | import com.ruoyi.utils.sdk.common.GlobalVariable; |
| | | import com.ruoyi.utils.sdk.hiksdk.lib.ExceptionCallBack; |
| | | import com.ruoyi.utils.sdk.hiksdk.lib.HCNetSDK; |
| | | import com.sun.jna.NativeLong;
|
| | | import com.sun.jna.Platform;
|
| | | import com.sun.jna.Pointer;
|
| | | import com.sun.jna.ptr.IntByReference;
|
| | | import lombok.extern.slf4j.Slf4j;
|
| | | import org.springframework.scheduling.annotation.Async; |
| | | import org.springframework.stereotype.Service;
|
| | |
|
| | | import java.util.Base64;
|
| | | import javax.annotation.Resource;
|
| | | import java.io.*;
|
| | | import java.math.BigDecimal;
|
| | |
| | | import java.util.concurrent.PriorityBlockingQueue;
|
| | |
|
| | | import static com.ruoyi.utils.sdk.hiksdk.lib.HCNetSDK.*;
|
| | | import static com.ruoyi.utils.sdk.hiksdk.lib.HCNetSDK.NET_DVR_GET_GISINFO; |
| | |
|
| | | /**
|
| | | * @ClassName: hikClientServiceImpl
|
| | | * @Description: 海康æä½å®¢æ·ç«¯å®ç°ç±»
|
| | | * @Author: Administrator
|
| | | * @Date: 2023å¹´01æ17æ¥ 11:25
|
| | | * @Version: 1.2
|
| | | * @Description: 海康sdkçç¥ |
| | | * @ClassName: DhSdkStrategy |
| | | * @Author: åèä¹ |
| | | * @Date: 2023å¹´11æ07æ¥10:51:09 |
| | | **/
|
| | | @Slf4j(topic = "hikSdk")
|
| | | @Service
|
| | | public class HikClientServiceImpl implements IHikClientService {
|
| | |
|
| | | @Slf4j(topic = "hikSdk") |
| | | public class HikSdkStrategy implements SdkStrategy { |
| | | @Resource
|
| | | private IArdCamerasService ardCamerasService;
|
| | | @Resource
|
| | | private IArdChannelService ardChannelService;
|
| | | @Resource
|
| | | private IVtduService vtduService;
|
| | | private final Object lock = new Object();
|
| | | public static HCNetSDK hCNetSDK = HCNetSDK.hCNetSDK;
|
| | | private static FExceptionCallBack fExceptionCallBack;//å¼å¸¸åè°
|
| | |
|
| | | public static HCNetSDK hCNetSDK = HCNetSDK.hCNetSDK; |
| | | private static HCNetSDK.FExceptionCallBack fExceptionCallBack;//å¼å¸¸åè° |
| | |
|
| | | /**
|
| | | * @æè¿° 注åç»å½ åªæ¯æåæ¥ç»éï¼ä¸å®æ¹ä¸å»ºè®®ç´æ¥å¨æ¤æ¥å£ä¸åèæ¶æä½
|
| | |
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯
|
| | | */
|
| | | @Override
|
| | | public void login(ArdCameras camera) {
|
| | | public boolean login(ArdCameras camera) { |
| | | try {
|
| | | // åå§å
|
| | | if (!hCNetSDK.NET_DVR_Init()) {
|
| | |
| | | camera.setChanNum(0);
|
| | | camera.setLoginId(-1);
|
| | | camera.setState("0");
|
| | | //å é¤ç®¡çéé |
| | | ardChannelService.deleteArdChannelByDeviceId(camera.getId()); |
| | | ardCamerasService.updateArdCameras(camera); |
| | | return false; |
| | | } |
| | | |
| | | log.debug("Login Success [ " + camera.getIp() + ":" + camera.getPort() + " ]"); |
| | | if (fExceptionCallBack == null) { |
| | | fExceptionCallBack = new ExceptionCallBack();//å¼å¸¸åè° |
| | | //设置å¼å¸¸åè°å½æ°(å¯å¨åè°å½æ°ä¸è·å设å¤ä¸ä¸çº¿ç¶æç) |
| | | if (!hCNetSDK.NET_DVR_SetExceptionCallBack_V30(0, 0, fExceptionCallBack, null)) { |
| | | log.debug("Set fExceptionCallBack function fail"); |
| | | return false; |
| | | } else { |
| | | log.debug("Set fExceptionCallBack function successfully!"); |
| | | } |
| | | } |
| | | |
| | | if (GlobalVariable.loginMap.containsKey(camera.getId())) { |
| | | GlobalVariable.loginMap.remove(camera.getId()); |
| | | } |
| | | |
| | | //å é¤ç®¡çéé |
| | | ardChannelService.deleteArdChannelByDeviceId(camera.getId()); |
| | | GlobalVariable.loginMap.put(camera.getId(), lUserID); |
| | | GlobalVariable.loginCameraMap.put(lUserID, camera); |
| | | |
| | | camera.setLoginId(lUserID); |
| | | camera.setState("1"); |
| | | camera.setChanNum((int) m_strDeviceInfo.struDeviceV30.byChanNum); |
| | | camera.setStartDChan((int) m_strDeviceInfo.struDeviceV30.byStartDChan); |
| | | ardCamerasService.updateArdCameras(camera); |
| | | //è·åææ°éé |
| | | List<ArdChannel> cameraChannelList = getCameraChannelList(camera); |
| | | if (cameraChannelList.size() > 0) { |
| | | for (ArdChannel channel : cameraChannelList) { |
| | | channel.setId(IdUtils.simpleUUID()); |
| | | ardChannelService.insertArdChannel(channel); |
| | | } |
| | | //æ·»å å°æµåªä½ |
| | | for (ArdChannel channel : cameraChannelList) { |
| | | String name = camera.getId() + "_" + channel.getChanNo(); |
| | | String rtspSource = "rtsp://" + camera.getUsername() + ":" + camera.getPassword() + "@" + camera.getIp() + ":" + camera.getRtspPort() + "/h264/ch" + channel.getChanNo() + "/main/av_stream"; |
| | | Vtdu vtdu = vtduService.selectVtduByName(name); |
| | | if (vtdu != null) { |
| | | vtduService.deleteVtduByName(name); |
| | | } |
| | | //æ·»å å°æµåªä½ |
| | | vtdu = new Vtdu(); |
| | | vtdu.setRtspSource(rtspSource); |
| | | vtdu.setName(camera.getId() + "_" + channel.getChanNo()); |
| | | CameraCmd cmd = new CameraCmd(camera.getId(), channel.getChanNo()); |
| | | Map<String, Object> videoCompressionCfg = getVideoCompressionCfg(cmd); |
| | | if (videoCompressionCfg.get("videoEncType").equals("æ åh264")) { |
| | | vtdu.setIsCode("0");//é»è®¤ä¸è½¬ç |
| | | } else { |
| | | vtdu.setIsCode("1");//é»è®¤è½¬ç |
| | | } |
| | | vtdu.setMode("1");//é»è®¤CPU软解ç |
| | | vtdu.setCameraId(camera.getId()); |
| | | vtduService.insertVtdu(vtdu); |
| | | } |
| | | } |
| | | //å建å¼å¯¼éå |
| | | if (!GuidePriorityQueue.cameraQueueMap.containsKey(camera.getId())) { |
| | | Comparator<GuideTask> comparator = GuidePriorityQueue.getComparator(); |
| | | PriorityBlockingQueue<GuideTask> priorityQueue = new PriorityBlockingQueue<>(1000, comparator); |
| | | GuidePriorityQueue.cameraQueueMap.put(camera.getId(), priorityQueue); |
| | | } |
| | | |
| | | } catch (Exception ex) { |
| | | log.error("注å设å¤å¼å¸¸", ex); |
| | | } |
| | | return true; |
| | | } |
| | | |
| | | /** |
| | | * @æè¿° 注åç»å½ éæäºNET_DVR_Login_V30ï¼æ¯æåæ¥å弿¥ç»å½ |
| | | * @åæ° [dvrLogin] |
| | | * @è¿åå¼ java.lang.Integer |
| | | * @å建人 åèä¹ |
| | | * @å建æ¶é´ 2023/1/17 16:12 |
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯ |
| | | */ |
| | | @Override |
| | | @Async("loginExecutor") |
| | | public void asyncLogin(ArdCameras camera) { |
| | | try { |
| | | // åå§å |
| | | if (!hCNetSDK.NET_DVR_Init()) { |
| | | log.error("SDKåå§å失败"); |
| | | } |
| | | //æå°æµ·åº·sdkæ¥å¿ |
| | | if (Platform.isWindows()) { |
| | | String WIN_PATH = System.getProperty("user.dir") + File.separator + "ardLog" + File.separator + "logs" + File.separator; |
| | | hCNetSDK.NET_DVR_SetLogToFile(3, WIN_PATH, true); |
| | | } else { |
| | | hCNetSDK.NET_DVR_SetLogToFile(3, "/home/ardLog/hiklog", true); |
| | | } |
| | | String m_sDeviceIP = camera.getIp(); |
| | | String m_sUsername = camera.getUsername(); |
| | | String m_sPassword = camera.getPassword(); |
| | | short m_sPort = camera.getPort().shortValue(); |
| | | //è®¾ç½®è¿æ¥æ¶é´ä¸éè¿æ¶é´ |
| | | hCNetSDK.NET_DVR_SetConnectTime(2000, 1); |
| | | hCNetSDK.NET_DVR_SetReconnect(5000, true); |
| | | //设å¤ä¿¡æ¯, è¾åºåæ° |
| | | HCNetSDK.NET_DVR_DEVICEINFO_V40 m_strDeviceInfo = new HCNetSDK.NET_DVR_DEVICEINFO_V40(); |
| | | HCNetSDK.NET_DVR_USER_LOGIN_INFO m_strLoginInfo = new HCNetSDK.NET_DVR_USER_LOGIN_INFO(); |
| | | |
| | | // 注å设å¤-ç»å½åæ°ï¼å
æ¬è®¾å¤å°åãç»å½ç¨æ·ãå¯ç ç |
| | | m_strLoginInfo.sDeviceAddress = new byte[HCNetSDK.NET_DVR_DEV_ADDRESS_MAX_LEN]; |
| | | System.arraycopy(m_sDeviceIP.getBytes(), 0, m_strLoginInfo.sDeviceAddress, 0, m_sDeviceIP.length()); |
| | | m_strLoginInfo.sUserName = new byte[HCNetSDK.NET_DVR_LOGIN_USERNAME_MAX_LEN]; |
| | | System.arraycopy(m_sUsername.getBytes(), 0, m_strLoginInfo.sUserName, 0, m_sUsername.length()); |
| | | m_strLoginInfo.sPassword = new byte[HCNetSDK.NET_DVR_LOGIN_PASSWD_MAX_LEN]; |
| | | System.arraycopy(m_sPassword.getBytes(), 0, m_strLoginInfo.sPassword, 0, m_sPassword.length()); |
| | | m_strLoginInfo.wPort = m_sPort; |
| | | m_strLoginInfo.byVerifyMode = 0; |
| | | m_strLoginInfo.byLoginMode = 0; |
| | | //æ¯å¦å¼æ¥ç»å½ï¼0- å¦ï¼1- æ¯ windowsSDK鿝trueåfalse |
| | | m_strLoginInfo.bUseAsynLogin = false; |
| | | m_strLoginInfo.write(); |
| | | //忥ç»å½ |
| | | int lUserID = hCNetSDK.NET_DVR_Login_V40(m_strLoginInfo, m_strDeviceInfo); |
| | | if (lUserID < 0) { |
| | | log.debug("Login Failed [ " + camera.getIp() + ":" + camera.getPort() + " ],é误ç ï¼" + hCNetSDK.NET_DVR_GetLastError()); |
| | | camera.setChanNum(0); |
| | | camera.setLoginId(-1); |
| | | camera.setState("0"); |
| | | //å é¤ç®¡çéé |
| | | ardChannelService.deleteArdChannelByDeviceId(camera.getId()); |
| | | ardCamerasService.updateArdCameras(camera); |
| | | return;
|
| | | }
|
| | |
|
| | |
| | | }
|
| | |
|
| | | /**
|
| | | * @æè¿° 注åç»å½ éæäºNET_DVR_Login_V30ï¼æ¯æåæ¥å弿¥ç»å½
|
| | | * @åæ° [dvrLogin]
|
| | | * @è¿åå¼ java.lang.Integer
|
| | | * @å建人 åèä¹
|
| | | * @å建æ¶é´ 2023/1/17 16:12
|
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯
|
| | | */
|
| | | @Override
|
| | | public void asyncLogin(ArdCameras camera) {
|
| | | // åå§å
|
| | | if (!hCNetSDK.NET_DVR_Init()) {
|
| | | log.error("SDKåå§å失败");
|
| | | }
|
| | | //æå°æµ·åº·sdkæ¥å¿
|
| | | if (Platform.isWindows()) {
|
| | | String WIN_PATH = System.getProperty("user.dir") + File.separator + "ardLog" + File.separator + "logs" + File.separator;
|
| | | hCNetSDK.NET_DVR_SetLogToFile(3, WIN_PATH, true);
|
| | | } else {
|
| | | hCNetSDK.NET_DVR_SetLogToFile(3, "/home/ardLog/hiklog", true);
|
| | | }
|
| | | String m_sDeviceIP = camera.getIp();
|
| | | String m_sUsername = camera.getUsername();
|
| | | String m_sPassword = camera.getPassword();
|
| | | short m_sPort = camera.getPort().shortValue();
|
| | | //è®¾ç½®è¿æ¥æ¶é´ä¸éè¿æ¶é´
|
| | | hCNetSDK.NET_DVR_SetConnectTime(2000, 1);
|
| | | hCNetSDK.NET_DVR_SetReconnect(100000, true);
|
| | | //设å¤ä¿¡æ¯, è¾åºåæ°
|
| | | HCNetSDK.NET_DVR_DEVICEINFO_V40 m_strDeviceInfo = new HCNetSDK.NET_DVR_DEVICEINFO_V40();
|
| | | HCNetSDK.NET_DVR_USER_LOGIN_INFO m_strLoginInfo = new HCNetSDK.NET_DVR_USER_LOGIN_INFO();
|
| | |
|
| | | // 注å设å¤-ç»å½åæ°ï¼å
æ¬è®¾å¤å°åãç»å½ç¨æ·ãå¯ç ç
|
| | | m_strLoginInfo.sDeviceAddress = new byte[HCNetSDK.NET_DVR_DEV_ADDRESS_MAX_LEN];
|
| | | System.arraycopy(m_sDeviceIP.getBytes(), 0, m_strLoginInfo.sDeviceAddress, 0, m_sDeviceIP.length());
|
| | | m_strLoginInfo.sUserName = new byte[HCNetSDK.NET_DVR_LOGIN_USERNAME_MAX_LEN];
|
| | | System.arraycopy(m_sUsername.getBytes(), 0, m_strLoginInfo.sUserName, 0, m_sUsername.length());
|
| | | m_strLoginInfo.sPassword = new byte[HCNetSDK.NET_DVR_LOGIN_PASSWD_MAX_LEN];
|
| | | System.arraycopy(m_sPassword.getBytes(), 0, m_strLoginInfo.sPassword, 0, m_sPassword.length());
|
| | | m_strLoginInfo.wPort = m_sPort;
|
| | | m_strLoginInfo.byVerifyMode = 0;
|
| | | m_strLoginInfo.byLoginMode = 0;
|
| | | //æ¯å¦å¼æ¥ç»å½ï¼0- å¦ï¼1- æ¯ windowsSDK鿝trueåfalse
|
| | | m_strLoginInfo.bUseAsynLogin = true;
|
| | | //弿¥ç»å½åè°
|
| | | m_strLoginInfo.cbLoginResult = new LoginResultCallBack(camera);
|
| | | m_strLoginInfo.write();
|
| | | int i = hCNetSDK.NET_DVR_Login_V40(m_strLoginInfo, m_strDeviceInfo);
|
| | | if (i < 0) {
|
| | | int errorCode = hCNetSDK.NET_DVR_GetLastError();
|
| | | log.error("ç»å½å¼å¸¸ï¼" + errorCode);
|
| | | }
|
| | |
|
| | | }
|
| | |
|
| | |
|
| | | /**
|
| | | * @æè¿° 注éç»å½
|
| | | * @åæ° [dvrLogin]
|
| | | * @è¿åå¼ java.lang.Integer
|
| | |
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯
|
| | | */
|
| | | @Override
|
| | | @SdkOperate
|
| | | public boolean pTZControlWithSpeed(CameraCmd cmd) {
|
| | | public boolean pTZControl(CameraCmd cmd) { |
| | | String cameraId = cmd.getCameraId();
|
| | | boolean enable = cmd.isEnable();
|
| | | Integer channelNum = cmd.getChanNo();
|
| | |
| | | * @å建æ¶é´ 2023/1/17 16:36
|
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯ 0-è§£é 1-éå®
|
| | | */
|
| | | @Override
|
| | | public int getPTZLockInfo(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer channelNum = cmd.getChanNo();
|
| | |
| | | * @ä¿®æ¹äººåå
¶å®ä¿¡æ¯ 注æä¿¯ä»°è§åº¦è´å¼éè¦å ä¸360å¾å°çæ£å¼è¿è¡è®¾ç½®
|
| | | */
|
| | | @Override
|
| | | @SdkOperate
|
| | | public boolean setZeroPtz(CameraCmd cmd) {
|
| | | String cameraId = cmd.getCameraId();
|
| | | Integer channelNum = cmd.getChanNo();
|