From d70903ea176f6856636ef57dffac73feaae56bac Mon Sep 17 00:00:00 2001
From: ‘liusuyi’ <1951119284@qq.com>
Date: 星期二, 04 七月 2023 17:22:23 +0800
Subject: [PATCH] 推送ptz获取相机方式更改为从redis中获取

---
 ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java |    5 
 ruoyi-common/src/main/java/com/ruoyi/common/constant/CacheConstants.java                |   11 +
 ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java                           |   98 ++++++++++--------
 ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java   |   15 +-
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java         |    1 
 ruoyi-common/src/main/java/com/ruoyi/common/core/redis/RedisCache.java                  |  106 +++++++++-----------
 ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java  |   46 ++++++++-
 7 files changed, 162 insertions(+), 120 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java b/ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java
index cbd7f4e..7a1a5be 100644
--- a/ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/device/camera/service/impl/ArdCamerasServiceImpl.java
@@ -3,10 +3,12 @@
 import java.time.LocalTime;
 import java.util.*;
 
+import com.ruoyi.common.constant.CacheConstants;
 import com.ruoyi.common.core.domain.entity.SysDept;
 import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.utils.DateUtils;
 import com.ruoyi.common.utils.SecurityUtils;
+import com.ruoyi.common.utils.uuid.IdUtils;
 import com.ruoyi.device.camera.domain.CameraCmd;
 import com.ruoyi.device.hiksdk.common.GlobalVariable;
 import com.ruoyi.system.domain.SysConfig;
@@ -39,6 +41,25 @@
     @Resource
     private RedisCache redisCache;
 
+
+    @PostConstruct
+    public void loadCameras() {
+        List<ArdCameras> ardCameras = selectArdCamerasListNoDataScope(new ArdCameras());
+        for (ArdCameras ardCamera : ardCameras) {
+            redisCache.setCacheObject(getCacheKey(ardCamera.getId()), ardCamera);
+        }
+
+    }
+
+    /**
+     * 璁剧疆cache key
+     *
+     * @param configKey 鍙傛暟閿�
+     * @return 缂撳瓨閿甼ey
+     */
+    private String getCacheKey(String configKey) {
+        return CacheConstants.CAMERA_LIST_KEY + configKey;
+    }
 
     /**
      * 鏌ヨ鐩告満璁惧
@@ -82,9 +103,11 @@
      */
     @Override
     public int insertArdCameras(ArdCameras ardCameras) {
+        ardCameras.setId(IdUtils.simpleUUID());
         ardCameras.setCreateBy(SecurityUtils.getUsername());
         ardCameras.setCreateTime(DateUtils.getNowDate());
         ardCameras.setUserId(SecurityUtils.getUserId());
+        redisCache.setCacheObject(getCacheKey(ardCameras.getId()), ardCameras);
         return ardCamerasMapper.insertArdCameras(ardCameras);
     }
 
@@ -97,7 +120,12 @@
     @Override
     public int updateArdCameras(ArdCameras ardCameras) {
         ardCameras.setUpdateTime(DateUtils.getNowDate());
-        return ardCamerasMapper.updateArdCameras(ardCameras);
+        int res = ardCamerasMapper.updateArdCameras(ardCameras);
+        if (res > 0) {
+            redisCache.deleteObject(getCacheKey(ardCameras.getId()));
+            redisCache.setCacheObject(getCacheKey(ardCameras.getId()), ardCameras);
+        }
+        return res;
     }
 
     /**
@@ -108,7 +136,15 @@
      */
     @Override
     public int deleteArdCamerasByIds(String[] ids) {
-        return ardCamerasMapper.deleteArdCamerasByIds(ids);
+        int res = ardCamerasMapper.deleteArdCamerasByIds(ids);
+        if(res>0)
+        {
+            for(String id:ids)
+            {
+                redisCache.deleteObject(getCacheKey(id));
+            }
+        }
+        return res;
     }
 
     /**
@@ -139,7 +175,7 @@
     public Map getChildDeptAndCamera(Boolean disabled) {
         Long deptId = SecurityUtils.getDeptId();
         SysDept sysDept = sysDeptMapper.selectDeptById(deptId);
-        Map<String, Object> map = fetchChildDepartments(sysDept,disabled);
+        Map<String, Object> map = fetchChildDepartments(sysDept, disabled);
         return map;
     }
 
@@ -151,7 +187,7 @@
      * @鍒涘缓鏃堕棿 2023/6/2 14:38
      * @淇敼浜哄拰鍏跺畠淇℃伅
      */
-    public Map<String, Object> fetchChildDepartments(SysDept sysDept,Boolean disabled) {
+    public Map<String, Object> fetchChildDepartments(SysDept sysDept, Boolean disabled) {
         Map<String, Object> map = new HashMap<>();
         map.put("name", sysDept.getDeptName());
         map.put("deptId", sysDept.getDeptId());
@@ -164,7 +200,7 @@
             childMap.put("name", childDept.getDeptName());
             childMap.put("deptId", childDept.getDeptId());
             childMap.put("disabled", disabled);
-            Map<String, Object> map1 = fetchChildDepartments(childDept,disabled);
+            Map<String, Object> map1 = fetchChildDepartments(childDept, disabled);
             childMap.putAll(map1);
             childList.add(childMap);
         }
diff --git a/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java b/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java
index 590b551..ba67776 100644
--- a/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/device/hiksdk/service/impl/HikClientServiceImpl.java
@@ -4,6 +4,7 @@
 import com.ruoyi.common.utils.file.FileUtils;
 import com.ruoyi.device.camera.domain.CameraCmd;
 import com.ruoyi.device.camera.mapper.ArdCamerasMapper;
+import com.ruoyi.device.camera.service.IArdCamerasService;
 import com.ruoyi.device.hiksdk.common.GlobalVariable;
 import com.ruoyi.device.camera.domain.ArdCameras;
 import com.ruoyi.device.hiksdk.config.MinioClientSingleton;
@@ -41,7 +42,7 @@
 public class HikClientServiceImpl implements IHikClientService {
 
     @Resource
-    ArdCamerasMapper ardCamerasMapper;
+    IArdCamerasService ardCamerasService;
 
     private static HCNetSDK hCNetSDK;
 
@@ -194,7 +195,7 @@
     public void loginAll() {
         try {
             log.debug("鍔犺浇lib瀹屾垚锛�");
-            List<ArdCameras> ardCameras = ardCamerasMapper.selectArdCamerasListNoDataScope(new ArdCameras());
+            List<ArdCameras> ardCameras = ardCamerasService.selectArdCamerasListNoDataScope(new ArdCameras());
             for (ArdCameras camera : ardCameras) {
                 Thread.sleep(500);
                 login(camera);
@@ -647,7 +648,7 @@
         NET_DVR_PTZPOS m_ptzPosCurrent = new NET_DVR_PTZPOS();
         m_ptzPosCurrent.wAction = 1;
         try {
-            ArdCameras cameras = ardCamerasMapper.selectArdCamerasById(cameraId);
+            ArdCameras cameras = ardCamerasService.selectArdCamerasById(cameraId);
             double[] cameraPositon = new double[]{cameras.getLongitude(), cameras.getLatitude(), cameras.getAltitude()};
             double[] targetPositions = cmd.getTargetPosition();
             double[] cameraPTZ = GisUtil.getCameraPTZ(cameraPositon, targetPositions, 20, 150);
@@ -683,11 +684,11 @@
     @SdkOperate
     public boolean controlLock(CameraCmd cmd) {
         String cameraId = cmd.getCameraId();//鐢宠閿佺殑鐩告満
-        ArdCameras ardCameras = ardCamerasMapper.selectArdCamerasById(cameraId);
+        ArdCameras ardCameras = ardCamerasService.selectArdCamerasById(cameraId);
         Date now = new Date();
         now.setTime(now.getTime() + cmd.getExpired() * 1000);
         ardCameras.setOperatorExpired(now);//璁剧疆褰撳墠杩囨湡鏃堕棿
-        ardCamerasMapper.updateArdCameras(ardCameras);
+        ardCamerasService.updateArdCameras(ardCameras);
         return true;
     }
 
@@ -703,11 +704,11 @@
     public boolean controlUnLock(CameraCmd cmd) {
         String cameraId = cmd.getCameraId();//鐢宠瑙i攣鐨勭浉鏈�
         String operator = cmd.getOperator();//鐢宠鑰�
-        ArdCameras ardCameras = ardCamerasMapper.selectArdCamerasById(cameraId);
+        ArdCameras ardCameras = ardCamerasService.selectArdCamerasById(cameraId);
         if (ardCameras.getOperatorId().equals(operator)) {
             //濡傛灉瑙i攣鐩告満鐨勫綋鍓嶇敤鎴锋槸鐢宠鑰咃紝鍒欐竻绌鸿鐩告満鐨勮繃鏈熸椂闂�
             ardCameras.setOperatorExpired(null);
-            int i = ardCamerasMapper.updateArdCameras(ardCameras);
+            int i = ardCamerasService.updateArdCameras(ardCameras);
             if (i > 0) {
                 log.debug(cameraId + "--瑙i攣鎴愬姛");
             }
diff --git a/ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java b/ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java
index 4ea42ef..e258fc5 100644
--- a/ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java
+++ b/ard-work/src/main/java/com/ruoyi/device/hiksdk/util/hikSdkUtil/LoginResultCallBack.java
@@ -5,6 +5,7 @@
 import com.ruoyi.common.utils.spring.SpringUtils;
 import com.ruoyi.device.camera.domain.ArdCameras;
 import com.ruoyi.device.camera.mapper.ArdCamerasMapper;
+import com.ruoyi.device.camera.service.IArdCamerasService;
 import com.ruoyi.device.hiksdk.common.GlobalVariable;
 import com.sun.jna.Pointer;
 import lombok.extern.slf4j.Slf4j;
@@ -50,8 +51,8 @@
             camera.setChannel(0);
             camera.setLoginId(-1);
         }
-        ArdCamerasMapper ardCamerasMapper = SpringUtils.getBean(ArdCamerasMapper.class);
-        ardCamerasMapper.updateArdCameras(camera);
+        IArdCamerasService ardCamerasService = SpringUtils.getBean(IArdCamerasService.class);
+        ardCamerasService.updateArdCameras(camera);
         return 1;
     }
 }
diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java
index 1c0e2f1..c9fe349 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/monitor/CacheController.java
@@ -43,6 +43,7 @@
         caches.add(new SysCache(CacheConstants.RATE_LIMIT_KEY, "闄愭祦澶勭悊"));
         caches.add(new SysCache(CacheConstants.PWD_ERR_CNT_KEY, "瀵嗙爜閿欒娆℃暟"));
         caches.add(new SysCache(CacheConstants.AUTH_CONFIG_KEY, "鎺堟潈閰嶇疆淇℃伅"));
+        caches.add(new SysCache(CacheConstants.CAMERA_LIST_KEY, "鐩告満鍒楄〃"));
     }
 
     @PreAuthorize("@ss.hasPermi('monitor:cache:list')")
diff --git a/ruoyi-common/src/main/java/com/ruoyi/common/constant/CacheConstants.java b/ruoyi-common/src/main/java/com/ruoyi/common/constant/CacheConstants.java
index 346a654..55cfcbc 100644
--- a/ruoyi-common/src/main/java/com/ruoyi/common/constant/CacheConstants.java
+++ b/ruoyi-common/src/main/java/com/ruoyi/common/constant/CacheConstants.java
@@ -2,11 +2,10 @@
 
 /**
  * 缂撳瓨鐨刱ey 甯搁噺
- * 
+ *
  * @author ruoyi
  */
-public class CacheConstants
-{
+public class CacheConstants {
     /**
      * 鐧诲綍鐢ㄦ埛 redis key
      */
@@ -41,8 +40,14 @@
      * 鐧诲綍璐︽埛瀵嗙爜閿欒娆℃暟 redis key
      */
     public static final String PWD_ERR_CNT_KEY = "pwd_err_cnt:";
+
     /**
      * 鎺堟潈浣跨敤鏈哄櫒鐮� redis key
      */
     public static final String AUTH_CONFIG_KEY = "auth_config:";
+
+    /**
+     * 鎵�鏈夌浉鏈� redis key
+     */
+    public static final String CAMERA_LIST_KEY = "camera_list:";
 }
diff --git a/ruoyi-common/src/main/java/com/ruoyi/common/core/redis/RedisCache.java b/ruoyi-common/src/main/java/com/ruoyi/common/core/redis/RedisCache.java
index 44e80d8..1098fd8 100644
--- a/ruoyi-common/src/main/java/com/ruoyi/common/core/redis/RedisCache.java
+++ b/ruoyi-common/src/main/java/com/ruoyi/common/core/redis/RedisCache.java
@@ -6,6 +6,7 @@
 import java.util.Map;
 import java.util.Set;
 import java.util.concurrent.TimeUnit;
+
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.data.redis.core.BoundSetOperations;
 import org.springframework.data.redis.core.HashOperations;
@@ -18,59 +19,54 @@
  *
  * @author ruoyi
  **/
-@SuppressWarnings(value = { "unchecked", "rawtypes" })
+@SuppressWarnings(value = {"unchecked", "rawtypes"})
 @Component
-public class RedisCache
-{
+public class RedisCache {
     @Autowired
     public RedisTemplate redisTemplate;
 
     /**
      * 缂撳瓨鍩烘湰鐨勫璞★紝Integer銆丼tring銆佸疄浣撶被绛�
      *
-     * @param key 缂撳瓨鐨勯敭鍊�
+     * @param key   缂撳瓨鐨勯敭鍊�
      * @param value 缂撳瓨鐨勫��
      */
-    public <T> void setCacheObject(final String key, final T value)
-    {
+    public <T> void setCacheObject(final String key, final T value) {
         redisTemplate.opsForValue().set(key, value);
     }
 
     /**
      * 缂撳瓨鍩烘湰鐨勫璞★紝Integer銆丼tring銆佸疄浣撶被绛�
      *
-     * @param key 缂撳瓨鐨勯敭鍊�
-     * @param value 缂撳瓨鐨勫��
-     * @param timeout 鏃堕棿
+     * @param key      缂撳瓨鐨勯敭鍊�
+     * @param value    缂撳瓨鐨勫��
+     * @param timeout  鏃堕棿
      * @param timeUnit 鏃堕棿棰楃矑搴�
      */
-    public <T> void setCacheObject(final String key, final T value, final Integer timeout, final TimeUnit timeUnit)
-    {
+    public <T> void setCacheObject(final String key, final T value, final Integer timeout, final TimeUnit timeUnit) {
         redisTemplate.opsForValue().set(key, value, timeout, timeUnit);
     }
 
     /**
      * 璁剧疆鏈夋晥鏃堕棿
      *
-     * @param key Redis閿�
+     * @param key     Redis閿�
      * @param timeout 瓒呮椂鏃堕棿
      * @return true=璁剧疆鎴愬姛锛沠alse=璁剧疆澶辫触
      */
-    public boolean expire(final String key, final long timeout)
-    {
+    public boolean expire(final String key, final long timeout) {
         return expire(key, timeout, TimeUnit.SECONDS);
     }
 
     /**
      * 璁剧疆鏈夋晥鏃堕棿
      *
-     * @param key Redis閿�
+     * @param key     Redis閿�
      * @param timeout 瓒呮椂鏃堕棿
-     * @param unit 鏃堕棿鍗曚綅
+     * @param unit    鏃堕棿鍗曚綅
      * @return true=璁剧疆鎴愬姛锛沠alse=璁剧疆澶辫触
      */
-    public boolean expire(final String key, final long timeout, final TimeUnit unit)
-    {
+    public boolean expire(final String key, final long timeout, final TimeUnit unit) {
         return redisTemplate.expire(key, timeout, unit);
     }
 
@@ -80,8 +76,7 @@
      * @param key Redis閿�
      * @return 鏈夋晥鏃堕棿
      */
-    public long getExpire(final String key)
-    {
+    public long getExpire(final String key) {
         return redisTemplate.getExpire(key);
     }
 
@@ -91,8 +86,7 @@
      * @param key 閿�
      * @return true 瀛樺湪 false涓嶅瓨鍦�
      */
-    public Boolean hasKey(String key)
-    {
+    public Boolean hasKey(String key) {
         return redisTemplate.hasKey(key);
     }
 
@@ -102,8 +96,7 @@
      * @param key 缂撳瓨閿��
      * @return 缂撳瓨閿�煎搴旂殑鏁版嵁
      */
-    public <T> T getCacheObject(final String key)
-    {
+    public <T> T getCacheObject(final String key) {
         ValueOperations<String, T> operation = redisTemplate.opsForValue();
         return operation.get(key);
     }
@@ -113,8 +106,7 @@
      *
      * @param key
      */
-    public boolean deleteObject(final String key)
-    {
+    public boolean deleteObject(final String key) {
         return redisTemplate.delete(key);
     }
 
@@ -124,20 +116,18 @@
      * @param collection 澶氫釜瀵硅薄
      * @return
      */
-    public boolean deleteObject(final Collection collection)
-    {
+    public boolean deleteObject(final Collection collection) {
         return redisTemplate.delete(collection) > 0;
     }
 
     /**
      * 缂撳瓨List鏁版嵁
      *
-     * @param key 缂撳瓨鐨勯敭鍊�
+     * @param key      缂撳瓨鐨勯敭鍊�
      * @param dataList 寰呯紦瀛樼殑List鏁版嵁
      * @return 缂撳瓨鐨勫璞�
      */
-    public <T> long setCacheList(final String key, final List<T> dataList)
-    {
+    public <T> long setCacheList(final String key, final List<T> dataList) {
         Long count = redisTemplate.opsForList().rightPushAll(key, dataList);
         return count == null ? 0 : count;
     }
@@ -148,24 +138,21 @@
      * @param key 缂撳瓨鐨勯敭鍊�
      * @return 缂撳瓨閿�煎搴旂殑鏁版嵁
      */
-    public <T> List<T> getCacheList(final String key)
-    {
+    public <T> List<T> getCacheList(final String key) {
         return redisTemplate.opsForList().range(key, 0, -1);
     }
 
     /**
      * 缂撳瓨Set
      *
-     * @param key 缂撳瓨閿��
+     * @param key     缂撳瓨閿��
      * @param dataSet 缂撳瓨鐨勬暟鎹�
      * @return 缂撳瓨鏁版嵁鐨勫璞�
      */
-    public <T> BoundSetOperations<String, T> setCacheSet(final String key, final Set<T> dataSet)
-    {
+    public <T> BoundSetOperations<String, T> setCacheSet(final String key, final Set<T> dataSet) {
         BoundSetOperations<String, T> setOperation = redisTemplate.boundSetOps(key);
         Iterator<T> it = dataSet.iterator();
-        while (it.hasNext())
-        {
+        while (it.hasNext()) {
             setOperation.add(it.next());
         }
         return setOperation;
@@ -177,8 +164,7 @@
      * @param key
      * @return
      */
-    public <T> Set<T> getCacheSet(final String key)
-    {
+    public <T> Set<T> getCacheSet(final String key) {
         return redisTemplate.opsForSet().members(key);
     }
 
@@ -188,8 +174,7 @@
      * @param key
      * @param dataMap
      */
-    public <T> void setCacheMap(final String key, final Map<String, T> dataMap)
-    {
+    public <T> void setCacheMap(final String key, final Map<String, T> dataMap) {
         if (dataMap != null) {
             redisTemplate.opsForHash().putAll(key, dataMap);
         }
@@ -201,32 +186,29 @@
      * @param key
      * @return
      */
-    public <T> Map<String, T> getCacheMap(final String key)
-    {
+    public <T> Map<String, T> getCacheMap(final String key) {
         return redisTemplate.opsForHash().entries(key);
     }
 
     /**
      * 寰�Hash涓瓨鍏ユ暟鎹�
      *
-     * @param key Redis閿�
-     * @param hKey Hash閿�
+     * @param key   Redis閿�
+     * @param hKey  Hash閿�
      * @param value 鍊�
      */
-    public <T> void setCacheMapValue(final String key, final String hKey, final T value)
-    {
+    public <T> void setCacheMapValue(final String key, final String hKey, final T value) {
         redisTemplate.opsForHash().put(key, hKey, value);
     }
 
     /**
      * 鑾峰彇Hash涓殑鏁版嵁
      *
-     * @param key Redis閿�
+     * @param key  Redis閿�
      * @param hKey Hash閿�
      * @return Hash涓殑瀵硅薄
      */
-    public <T> T getCacheMapValue(final String key, final String hKey)
-    {
+    public <T> T getCacheMapValue(final String key, final String hKey) {
         HashOperations<String, String, T> opsForHash = redisTemplate.opsForHash();
         return opsForHash.get(key, hKey);
     }
@@ -234,24 +216,22 @@
     /**
      * 鑾峰彇澶氫釜Hash涓殑鏁版嵁
      *
-     * @param key Redis閿�
+     * @param key   Redis閿�
      * @param hKeys Hash閿泦鍚�
      * @return Hash瀵硅薄闆嗗悎
      */
-    public <T> List<T> getMultiCacheMapValue(final String key, final Collection<Object> hKeys)
-    {
+    public <T> List<T> getMultiCacheMapValue(final String key, final Collection<Object> hKeys) {
         return redisTemplate.opsForHash().multiGet(key, hKeys);
     }
 
     /**
      * 鍒犻櫎Hash涓殑鏌愭潯鏁版嵁
      *
-     * @param key Redis閿�
+     * @param key  Redis閿�
      * @param hKey Hash閿�
      * @return 鏄惁鎴愬姛
      */
-    public boolean deleteCacheMapValue(final String key, final String hKey)
-    {
+    public boolean deleteCacheMapValue(final String key, final String hKey) {
         return redisTemplate.opsForHash().delete(key, hKey) > 0;
     }
 
@@ -261,8 +241,16 @@
      * @param pattern 瀛楃涓插墠缂�
      * @return 瀵硅薄鍒楄〃
      */
-    public Collection<String> keys(final String pattern)
-    {
+    public Collection<String> keys(final String pattern) {
         return redisTemplate.keys(pattern);
     }
+
+    /**
+     * 鏍规嵁鍓嶇紑鑾峰彇鎵�鏈夌殑key* 渚嬪锛歱ro_
+     */
+    public List<Object> getListKey(String prefix) {
+        Set<Object> keys = redisTemplate.keys(prefix+"*");
+        List<Object> values = redisTemplate.opsForValue().multiGet(keys);
+        return values;
+    }
 }
diff --git a/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java b/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java
index 4fcc320..78edeb6 100644
--- a/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java
+++ b/ruoyi-quartz/src/main/java/com/ruoyi/quartz/task/SdkTask.java
@@ -1,6 +1,8 @@
 package com.ruoyi.quartz.task;
 
+import com.ruoyi.common.constant.CacheConstants;
 import com.ruoyi.common.core.domain.entity.SysUser;
+import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.utils.DateUtils;
 import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.common.utils.spring.SpringUtils;
@@ -40,60 +42,68 @@
      */
     public void ptzPush() {
         try {
+            RedisCache redisCache = SpringUtils.getBean(RedisCache.class);
             ISysUserService sysUserService = SpringUtils.getBean(ISysUserService.class);
-            IArdCamerasService ardCamerasService = SpringUtils.getBean(IArdCamerasService.class);
             IHikClientService hikClientService = SpringUtils.getBean(IHikClientService.class);
             List<Map<String, Object>> list = new ArrayList<>();
             ArdCameras ardCameras = new ArdCameras();
             ardCameras.setGdtype("1");
-            List<ArdCameras> ardCamerasList = ardCamerasService.selectArdCamerasListNoDataScope(ardCameras);
-            for (ArdCameras camera : ardCamerasList) {
-                CameraCmd cmd = new CameraCmd();
-                cmd.setCameraId(camera.getId());
-                cmd.setChannelNum(1);
-                cmd.setOperator(camera.getOperatorId());
-                if (!GlobalVariable.loginMap.containsKey(camera.getId()))//鍙帹閫佺櫥褰曟垚鍔熺殑鐩告満
-                {
-                    continue;
-                }
-                Map<String, Object> ptz = hikClientService.getPtz(cmd);
-                if (StringUtils.isNull(ptz)) {
-                    continue;
-                }
-                SysUser sysUser = sysUserService.selectUserById(camera.getOperatorId());
-                if (StringUtils.isNotNull(sysUser)) {
-                    cmd.setOperatorZh(sysUser.getNickName());
-                } else {
-                    cmd.setOperatorZh(cmd.getOperator());
-                }
-
-                //鑾峰彇鏃堕棿宸�
-                long secDatePoor = 0;
-                if (StringUtils.isNotNull(camera.getOperatorExpired())) {
-                    secDatePoor = DateUtils.getSecDatePoor(camera.getOperatorExpired(), new Date());
-                    if(secDatePoor<0)
+            List<Object> Objects = redisCache.getListKey(getCacheKey());
+            if (Objects.size() > 0) {
+                for (Object obj : Objects) {
+                    ArdCameras camera = (ArdCameras) obj;
+                    CameraCmd cmd = new CameraCmd();
+                    cmd.setCameraId(camera.getId());
+                    cmd.setChannelNum(1);
+                    cmd.setOperator(camera.getOperatorId());
+                    if (!GlobalVariable.loginMap.containsKey(camera.getId()))//鍙帹閫佺櫥褰曟垚鍔熺殑鐩告満
                     {
-                        secDatePoor=0;
+                        continue;
+                    }
+                    Map<String, Object> ptz = hikClientService.getPtz(cmd);
+                    if (StringUtils.isNull(ptz)) {
+                        continue;
+                    }
+                    SysUser sysUser = sysUserService.selectUserById(camera.getOperatorId());
+                    if (StringUtils.isNotNull(sysUser)) {
+                        cmd.setOperatorZh(sysUser.getNickName());
+                    } else {
+                        cmd.setOperatorZh(cmd.getOperator());
+                    }
+
+                    //鑾峰彇鏃堕棿宸�
+                    long secDatePoor = 0;
+                    if (StringUtils.isNotNull(camera.getOperatorExpired())) {
+                        secDatePoor = DateUtils.getSecDatePoor(camera.getOperatorExpired(), new Date());
+                        if (secDatePoor < 0) {
+                            secDatePoor = 0;
+                        }
+                    }
+
+                    if (ptz.size() > 0) {
+                        ptz.put("cameraId", cmd.getCameraId());
+                        ptz.put("usernameZh", cmd.getOperatorZh());
+                        ptz.put("operatorId", cmd.getOperator());//涓婇攣鐢ㄦ埛id
+                        ptz.put("expirationRemainingSecond", secDatePoor);
+                        list.add(ptz);
                     }
                 }
-
-                if (ptz.size() > 0) {
-                    ptz.put("cameraId", cmd.getCameraId());
-                    ptz.put("usernameZh", cmd.getOperatorZh());
-                    ptz.put("operatorId", cmd.getOperator());//涓婇攣鐢ㄦ埛id
-                    ptz.put("expirationRemainingSecond", secDatePoor);
-                    list.add(ptz);
+                if (ONLINE_USER_SESSIONS.size() > 0) {
+                    Map<String, Object> sendMap = new HashMap<>();
+                    sendMap.put("10000", list);
+                    WebSocketUtils.sendMessageAll(sendMap);
                 }
             }
-            if (ONLINE_USER_SESSIONS.size() > 0) {
-                Map<String, Object> sendMap = new HashMap<>();
-                sendMap.put("10000", list);
-                WebSocketUtils.sendMessageAll(sendMap);
-            }
+        } catch (Exception ex) {
+            log.error("鎺ㄩ�乸tz寮傚父:" + ex.getMessage());
         }
-        catch (Exception ex)
-        {
-            log.error("鎺ㄩ�乸tz寮傚父:"+ex.getMessage());
-        }
+    }
+    /**
+     * 鑾峰彇cache key
+     *
+     * @return 缂撳瓨閿甼ey
+     */
+    private String getCacheKey() {
+        return CacheConstants.CAMERA_LIST_KEY;
     }
 }

--
Gitblit v1.9.3