From 0f5901bbc027e2e8d934280ca659734a61f67378 Mon Sep 17 00:00:00 2001
From: zhanghua <314079846@qq.com>
Date: 星期二, 04 三月 2025 15:00:35 +0800
Subject: [PATCH] 图片显示修改,删除脏数据

---
 ycl-platform/src/main/java/com/ycl/task/SynchronizeDHAlarm.java                |   50 ++++++++
 ycl-smoke/pom.xml                                                              |   12 +-
 ycl-common/src/main/java/com/ycl/utils/ConstantPropertiesUtils.java            |    5 
 ycl-platform/src/main/resources/application-dev.yml                            |    5 
 ycl-platform/src/main/java/com/ycl/OSSImageMove.java                           |  139 +++++++++++++++++++++++
 ycl-platform/src/main/java/com/ycl/vo/casePool/BaseCaseVO.java                 |    1 
 document/遂昌县大综合一体化驾驶舱数据源核对会议.xls                                               |    0 
 pom.xml                                                                        |    2 
 ycl-common/src/main/java/com/ycl/service/oss/OssService.java                   |    3 
 document/问题类型.xls                                                              |    0 
 ycl-platform/src/test/java/com/ycl/sccgplatform/Test1.java                     |   51 +++++++-
 ycl-platform/src/main/java/com/ycl/util/SpringContextUtil.java                 |   17 ++
 ycl-platform/src/main/resources/mapper/caseHandler/BaseCaseMapper.xml          |    1 
 ycl-common/src/main/java/com/ycl/controller/FileController.java                |    9 +
 ycl-platform/src/main/resources/application-prod.yml                           |    7 +
 ycl-platform/src/main/java/com/ycl/PlatformApplication.java                    |    9 +
 ycl-platform/src/main/java/com/ycl/entity/resources/ImageResources.java        |    3 
 ycl-common/src/main/java/com/ycl/service/oss/impl/OssServiceImpl.java          |   27 +++-
 ycl-platform/src/main/java/com/ycl/controller/platformApi/AlarmController.java |    7 
 19 files changed, 321 insertions(+), 27 deletions(-)

diff --git "a/document/\351\201\202\346\230\214\345\216\277\345\244\247\347\273\274\345\220\210\344\270\200\344\275\223\345\214\226\351\251\276\351\251\266\350\210\261\346\225\260\346\215\256\346\272\220\346\240\270\345\257\271\344\274\232\350\256\256.xls" "b/document/\351\201\202\346\230\214\345\216\277\345\244\247\347\273\274\345\220\210\344\270\200\344\275\223\345\214\226\351\251\276\351\251\266\350\210\261\346\225\260\346\215\256\346\272\220\346\240\270\345\257\271\344\274\232\350\256\256.xls"
index 7f66460..c9a01e4 100644
--- "a/document/\351\201\202\346\230\214\345\216\277\345\244\247\347\273\274\345\220\210\344\270\200\344\275\223\345\214\226\351\251\276\351\251\266\350\210\261\346\225\260\346\215\256\346\272\220\346\240\270\345\257\271\344\274\232\350\256\256.xls"
+++ "b/document/\351\201\202\346\230\214\345\216\277\345\244\247\347\273\274\345\220\210\344\270\200\344\275\223\345\214\226\351\251\276\351\251\266\350\210\261\346\225\260\346\215\256\346\272\220\346\240\270\345\257\271\344\274\232\350\256\256.xls"
Binary files differ
diff --git "a/document/\351\227\256\351\242\230\347\261\273\345\236\213.xls" "b/document/\351\227\256\351\242\230\347\261\273\345\236\213.xls"
index b1553dd..eb3df04 100644
--- "a/document/\351\227\256\351\242\230\347\261\273\345\236\213.xls"
+++ "b/document/\351\227\256\351\242\230\347\261\273\345\236\213.xls"
Binary files differ
diff --git a/pom.xml b/pom.xml
index 5b27209..db8f0dd 100644
--- a/pom.xml
+++ b/pom.xml
@@ -49,7 +49,7 @@
     <modules>
         <module>ycl-platform</module>
         <module>ycl-common</module>
-        <module>ycl-generator</module>
+<!--        <module>ycl-generator</module>-->
         <module>ycl-smoke</module>
     </modules>
 
diff --git a/ycl-common/src/main/java/com/ycl/controller/FileController.java b/ycl-common/src/main/java/com/ycl/controller/FileController.java
index 25c2a1e..76fbbbd 100644
--- a/ycl-common/src/main/java/com/ycl/controller/FileController.java
+++ b/ycl-common/src/main/java/com/ycl/controller/FileController.java
@@ -10,6 +10,8 @@
 import org.springframework.web.bind.annotation.RestController;
 import org.springframework.web.multipart.MultipartFile;
 
+import java.io.UnsupportedEncodingException;
+
 @RestController
 @Api(tags = "鏂囦欢涓婁紶")
 @RequestMapping("/file")
@@ -64,7 +66,12 @@
     @ApiOperation(value = "鍒犻櫎鍥剧墖")
     @PostMapping("media/delete")
     public CommonResult<Boolean> deleteImages(String fileUrl) {
-        boolean flag = ossService.deleteImages(fileUrl);
+        boolean flag = false;
+        try {
+            flag = ossService.deleteImages(fileUrl);
+        } catch (UnsupportedEncodingException e) {
+            throw new RuntimeException(e);
+        }
         if (flag) {
             return CommonResult.success(true, "鍒犻櫎鎴愬姛");
         }
diff --git a/ycl-common/src/main/java/com/ycl/service/oss/OssService.java b/ycl-common/src/main/java/com/ycl/service/oss/OssService.java
index 841024c..0a93c31 100644
--- a/ycl-common/src/main/java/com/ycl/service/oss/OssService.java
+++ b/ycl-common/src/main/java/com/ycl/service/oss/OssService.java
@@ -3,6 +3,7 @@
 import org.springframework.web.multipart.MultipartFile;
 
 import java.io.InputStream;
+import java.io.UnsupportedEncodingException;
 
 public interface OssService {
     /**
@@ -19,7 +20,7 @@
      * @param fileUrl
      * @return
      */
-    boolean deleteImages(String fileUrl);
+    boolean deleteImages(String fileUrl) throws UnsupportedEncodingException;
 
     String uploadImages(InputStream inputStream, String ext, Integer times);
 
diff --git a/ycl-common/src/main/java/com/ycl/service/oss/impl/OssServiceImpl.java b/ycl-common/src/main/java/com/ycl/service/oss/impl/OssServiceImpl.java
index 460c745..a4eb460 100644
--- a/ycl-common/src/main/java/com/ycl/service/oss/impl/OssServiceImpl.java
+++ b/ycl-common/src/main/java/com/ycl/service/oss/impl/OssServiceImpl.java
@@ -3,6 +3,7 @@
 import com.aliyun.oss.OSS;
 import com.aliyun.oss.OSSClientBuilder;
 import com.aliyun.oss.model.ObjectMetadata;
+import com.aliyun.oss.model.VoidResult;
 import com.ycl.service.oss.OssService;
 import com.ycl.utils.ConstantPropertiesUtils;
 import com.ycl.utils.common.RandomUtils;
@@ -17,6 +18,8 @@
 import java.awt.*;
 import java.awt.image.BufferedImage;
 import java.io.*;
+import java.net.URL;
+import java.net.URLDecoder;
 import java.time.LocalDate;
 import java.time.LocalDateTime;
 import java.time.format.DateTimeFormatter;
@@ -43,12 +46,14 @@
         // 涓婁紶鏂囦欢娴�
         try {
             // 鑾峰彇鏂囦欢鐨勫悕绉�
-            String strDate2 = dtf2.format(LocalDateTime.now());
+
             byte[] newImg = file.getBytes();
             String originalFilename = file.getOriginalFilename();
             String fileType = originalFilename.substring(originalFilename.lastIndexOf("."));
 
-            String fileName = "sczf/" + strDate2 + RandomUtils.generateRandomInt(4) + "." + fileType;
+            DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyyMMdd");
+            String fileName = "sczf/" + LocalDateTime.now().format(formatter) + RandomUtils.generateRandomInt(8) + fileType;
+
             if (".png".equalsIgnoreCase(fileType) || ".jpg".equalsIgnoreCase(fileType) || ".jpeg".equalsIgnoreCase(fileType)) {
                 if (file.getSize() > 2097152) {
                     newImg = compressUnderSize(file.getBytes(), 2097152);
@@ -65,6 +70,7 @@
             // 鎶婁笂浼犵殑鏂囦欢璺緞杩斿洖 锛堟墜鍔ㄦ嫾鎺ワ級
             // 杩欓噷璁剧疆鍥剧墖鏈夋晥鏃堕棿 鎴戣缃簡30骞�
             Date expiration = new Date(System.currentTimeMillis() + (long) 946080000 * 1000);
+
             String url = ossClient.generatePresignedUrl(bucketName, fileName, expiration).toString();
 
             System.out.println("涓婁紶缁撴潫--" + url + "------" + dtf2.format(LocalDateTime.now()));
@@ -148,18 +154,27 @@
     }
 
     @Override
-    public boolean deleteImages(String fileUrl) {
+    public boolean deleteImages(String fileUrl) throws UnsupportedEncodingException {
         String endpoint = ConstantPropertiesUtils.END_POINT;
         String accessKeyId = ConstantPropertiesUtils.ACCESS_KEY_ID;
         String accessKeySecret = ConstantPropertiesUtils.ACCESS_KEY_SECRET;
         String bucketName = ConstantPropertiesUtils.BUCKET_NAME;
         //鍒涘缓OSSClient瀹炰緥
         OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
-        String imgFile = fileUrl.replace("https://bucket-ans.oss-cn-hangzhou.aliyuncs.com/", "");
-        String fileName = imgFile.substring(0, imgFile.indexOf("?"));
+
+        String imgFile = fileUrl.replace(ConstantPropertiesUtils.PREFIX_URL, "");
+        String fileName = imgFile;
+        if (imgFile.contains("?")) {
+            fileName = imgFile.substring(0, imgFile.indexOf("?"));
+        }
+        fileName = URLDecoder.decode(fileName, "UTF-8");
 
         // 鏍规嵁BucketName,objectName鍒犻櫎鏂囦欢
-        ossClient.deleteObject(bucketName, fileName);
+        boolean b = ossClient.doesObjectExist(bucketName, fileName);
+        if (b) {
+            VoidResult voidResult = ossClient.deleteObject(bucketName, fileName);
+            System.out.println(voidResult.toString());
+        }
         ossClient.shutdown();
         return true;
     }
diff --git a/ycl-common/src/main/java/com/ycl/utils/ConstantPropertiesUtils.java b/ycl-common/src/main/java/com/ycl/utils/ConstantPropertiesUtils.java
index a97c2bc..7da39d4 100644
--- a/ycl-common/src/main/java/com/ycl/utils/ConstantPropertiesUtils.java
+++ b/ycl-common/src/main/java/com/ycl/utils/ConstantPropertiesUtils.java
@@ -16,11 +16,15 @@
     @Value("${aliyun.oss.bucketName}")
     private String bucketName;
 
+    @Value("${aliyun.oss.prefixUrl}")
+    private String prefixUrl;
+
     // 瀹氫箟鍏紑鐨勯潤鎬佸父閲�
     public static String END_POINT;
     public static String ACCESS_KEY_ID;
     public static String ACCESS_KEY_SECRET;
     public static String BUCKET_NAME;
+    public static String PREFIX_URL;
 
     @Override
     public void afterPropertiesSet() throws Exception {
@@ -28,5 +32,6 @@
         ACCESS_KEY_ID = keyId;
         ACCESS_KEY_SECRET = keySecret;
         BUCKET_NAME = bucketName;
+        PREFIX_URL = prefixUrl;
     }
 }
diff --git a/ycl-platform/src/main/java/com/ycl/OSSImageMove.java b/ycl-platform/src/main/java/com/ycl/OSSImageMove.java
new file mode 100644
index 0000000..59145f9
--- /dev/null
+++ b/ycl-platform/src/main/java/com/ycl/OSSImageMove.java
@@ -0,0 +1,139 @@
+package com.ycl;
+
+import com.aliyun.oss.OSS;
+import com.aliyun.oss.OSSClientBuilder;
+import com.aliyun.oss.OSSException;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ycl.entity.resources.ImageResources;
+import com.ycl.mapper.resources.ImageResourcesMapper;
+import com.ycl.service.oss.OssService;
+import com.ycl.util.SpringContextUtil;
+import com.ycl.utils.ConstantPropertiesUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+import org.springframework.stereotype.Service;
+
+import javax.annotation.Resource;
+import java.io.IOException;
+import java.io.InputStream;
+import java.net.HttpURLConnection;
+import java.net.URL;
+import java.util.Date;
+
+@Component
+public class OSSImageMove extends Thread {
+
+    @Resource
+    ImageResourcesMapper imageResourcesMapper;
+
+    @Autowired
+    OssService ossService;
+
+    public void run() {
+
+        System.out.println("---------------OSSImageMove running");
+
+        imageResourcesMapper = SpringContextUtil.getBean("imageResourcesMapper", ImageResourcesMapper.class);
+        ossService = SpringContextUtil.getBean("ossServiceImpl", OssService.class);
+
+        System.out.println("---------------OSSImageMove start");
+        int i = 1;
+        while (true) {
+            IPage<ImageResources> page = new Page<>(i, 10);
+            LambdaQueryWrapper<ImageResources> queryWrapper = new LambdaQueryWrapper<>();
+            queryWrapper.isNull(ImageResources::getUrl1).orderByDesc(ImageResources::getId);
+            imageResourcesMapper.selectPage(page, queryWrapper);
+            System.out.println("page-current:" + page.getCurrent() + "--page-total:" + page.getTotal());
+            if (page.getRecords().size() > 0) {
+                for (ImageResources imageResources : page.getRecords()) {
+                    try {
+
+                        System.out.println("source-url:" + imageResources.getUrl());
+
+                        String backUrl = extracted(imageResources.getUrl());
+
+                        System.out.println("new-url:" + imageResources.getUrl());
+                        imageResources.setUrl1(backUrl);
+                        imageResourcesMapper.updateById(imageResources);
+
+                    } catch (Exception e) {
+                        System.out.println("OSSImageMove-error:" + e.getMessage());
+                    }
+                }
+            } else {
+                break;
+            }
+            i++;
+        }
+
+        System.out.println("---------------OSSImageMove  Over");
+    }
+
+    private String extracted(String imageUrl) {
+        String[] urls = imageUrl.split(",");
+        StringBuilder backUrl = new StringBuilder();
+        for (int j = 0; j < urls.length; j++) {
+
+            URL url = translateOSSUrl(urls[j]);
+
+            HttpURLConnection conn = null;
+            try {
+                conn = (HttpURLConnection) url.openConnection();
+
+                conn.setRequestMethod("GET");
+                conn.setConnectTimeout(10 * 1000);
+                conn.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");
+
+                InputStream inputStream = conn.getInputStream();// 閫氳繃杈撳叆娴佽幏鍙栧浘鐗囨暟鎹�
+
+                if (inputStream != null) {
+                    String picData = ossService.uploadImages(inputStream, ".png", 0);
+                    backUrl.append(picData);
+                }
+            } catch (IOException e) {
+                System.out.println("OSSImageMove-translateOSSUrl-error:" + e.getMessage());
+                // throw new RuntimeException(e);
+            }
+        }
+        return backUrl.toString();
+    }
+
+
+    private URL translateOSSUrl(String fileUrl) {
+        OSS ossClient = null;
+        try {
+            String endpoint = ConstantPropertiesUtils.END_POINT;
+            String accessKeyId = ConstantPropertiesUtils.ACCESS_KEY_ID;
+            String accessKeySecret = ConstantPropertiesUtils.ACCESS_KEY_SECRET;
+            String bucketName = ConstantPropertiesUtils.BUCKET_NAME;
+
+            String[] urlArray = fileUrl.split("Expires=");
+
+            String objectName = urlArray[0].replace(ConstantPropertiesUtils.PREFIX_URL, "");
+            objectName = objectName.replace("?", "");
+
+            ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
+
+            // 璁剧疆绛惧悕URL杩囨湡鏃堕棿锛屽崟浣嶄负姣銆傛湰绀轰緥浠ヨ缃繃鏈熸椂闂翠负1灏忔椂涓轰緥銆�
+            Date expiration = new Date(new Date().getTime() + 3600 * 1000L);
+            // 鐢熸垚浠ET鏂规硶璁块棶鐨勭鍚峌RL銆傛湰绀轰緥娌℃湁棰濆璇锋眰澶达紝鍏朵粬浜哄彲浠ョ洿鎺ラ�氳繃娴忚鍣ㄨ闂浉鍏冲唴瀹广��
+            URL url = ossClient.generatePresignedUrl(bucketName, objectName, expiration);
+
+            return url;
+        } catch (OSSException oe) {
+            System.out.println("Caught an OSSException, which means your request made it to OSS, "
+                    + "but was rejected with an error response for some reason.");
+            System.out.println("Error Message:" + oe.getErrorMessage());
+            System.out.println("Error Code:" + oe.getErrorCode());
+            System.out.println("Request ID:" + oe.getRequestId());
+            System.out.println("Host ID:" + oe.getHostId());
+        } finally {
+            if (ossClient != null) {
+                ossClient.shutdown();
+            }
+        }
+        return null;
+    }
+}
diff --git a/ycl-platform/src/main/java/com/ycl/PlatformApplication.java b/ycl-platform/src/main/java/com/ycl/PlatformApplication.java
index 2e2b512..a362651 100644
--- a/ycl-platform/src/main/java/com/ycl/PlatformApplication.java
+++ b/ycl-platform/src/main/java/com/ycl/PlatformApplication.java
@@ -1,6 +1,7 @@
 package com.ycl;
 
 import com.dahua.netsdk.AppDemo;
+import com.ycl.util.SpringContextUtil;
 import com.ycl.util.VideoUtil;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.boot.SpringApplication;
@@ -48,5 +49,13 @@
         } catch (Exception e) {
             log.info("鎵ц澶у崕鎶ヨ绋嬪簭鍑洪敊锛�", e.getMessage());
         }
+
+//        try {
+//            // 鍚姩鏃讹紝淇濆瓨涓婁笅鏂囷紝骞朵繚瀛樹负闈欐��
+//            SpringContextUtil.setAc(application);
+//            new OSSImageMove().start();
+//        } catch (Exception e) {
+//            log.info("鍥剧墖绋嬪簭鍑洪敊锛�", e.getMessage());
+//        }
     }
 }
diff --git a/ycl-platform/src/main/java/com/ycl/controller/platformApi/AlarmController.java b/ycl-platform/src/main/java/com/ycl/controller/platformApi/AlarmController.java
index e3ea3f3..d5a1603 100644
--- a/ycl-platform/src/main/java/com/ycl/controller/platformApi/AlarmController.java
+++ b/ycl-platform/src/main/java/com/ycl/controller/platformApi/AlarmController.java
@@ -167,10 +167,13 @@
 
             String[] urlArray = fileUrl.split("Expires=");
 
-            String[] urlArray2 = urlArray[0].split("aliyuncs.com/");
+//            System.out.println("-------urlArray[0]:" + urlArray[0]);
 
-            String objectName = urlArray2[1].replace("?", "");
+//            System.out.println("-------PREFIX_URL:" + ConstantPropertiesUtils.PREFIX_URL);
+            String objectName = urlArray[0].replace(ConstantPropertiesUtils.PREFIX_URL, "");
 
+            objectName = objectName.replace("?", "");
+//            System.out.println("-------objectName:" + objectName);
             ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
 
             // 璁剧疆绛惧悕URL杩囨湡鏃堕棿锛屽崟浣嶄负姣銆傛湰绀轰緥浠ヨ缃繃鏈熸椂闂翠负1灏忔椂涓轰緥銆�
diff --git a/ycl-platform/src/main/java/com/ycl/entity/resources/ImageResources.java b/ycl-platform/src/main/java/com/ycl/entity/resources/ImageResources.java
index 21163df..96e1524 100644
--- a/ycl-platform/src/main/java/com/ycl/entity/resources/ImageResources.java
+++ b/ycl-platform/src/main/java/com/ycl/entity/resources/ImageResources.java
@@ -50,6 +50,9 @@
     @TableField("url")
     private String url;
 
+    @TableField("url1")
+    private String url1;
+
     /**
      * 鍒涘缓浜�
      */
diff --git a/ycl-platform/src/main/java/com/ycl/task/SynchronizeDHAlarm.java b/ycl-platform/src/main/java/com/ycl/task/SynchronizeDHAlarm.java
index 9f88d04..157eedb 100644
--- a/ycl-platform/src/main/java/com/ycl/task/SynchronizeDHAlarm.java
+++ b/ycl-platform/src/main/java/com/ycl/task/SynchronizeDHAlarm.java
@@ -1,12 +1,16 @@
 package com.ycl.task;
 
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.ycl.common.constant.GlobalQueue;
 import com.ycl.entity.video.VideoAlarmReport;
 import com.ycl.entity.video.VideoPoint;
+import com.ycl.service.caseHandler.IBaseCaseService;
 import com.ycl.service.caseHandler.IViolationsService;
 import com.ycl.service.oss.OssService;
+import com.ycl.service.resources.IImageResourcesService;
 import com.ycl.service.video.IVideoAlarmReportService;
 import com.ycl.service.video.impl.IVideoPointService;
+import com.ycl.vo.casePool.BaseCaseVO;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
@@ -14,6 +18,9 @@
 
 import java.io.ByteArrayInputStream;
 import java.io.InputStream;
+import java.io.UnsupportedEncodingException;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
 import java.util.ArrayList;
 import java.util.List;
 
@@ -31,6 +38,12 @@
 
     @Autowired
     private IViolationsService violationsService;
+
+    @Autowired
+    private IBaseCaseService baseCaseService;
+
+    @Autowired
+    private IImageResourcesService imageService;
 
     @Scheduled(cron = "0 */1 * * * ?")
     @Transactional(rollbackFor = Exception.class)
@@ -51,7 +64,7 @@
                     if (videoAlarmReport.getPicByte() != null) {
                         String extension = "jpg";
                         InputStream inputStream = new ByteArrayInputStream(videoAlarmReport.getPicByte());
-                        String picData = ossService.uploadImages(inputStream, extension,0);
+                        String picData = ossService.uploadImages(inputStream, extension, 0);
 
                         videoAlarmReport.setPicData(picData);
                     }
@@ -68,4 +81,39 @@
             }
         }
     }
+
+
+    @Scheduled(cron = "0 0 15 * * ?")
+    @Transactional(rollbackFor = Exception.class)
+    public void deleteAlarmTask() {
+        System.out.println("----------------鎵ц娓呴櫎鏁版嵁浠诲姟:");
+        int i = 1;
+        while (true) {
+            String beginTime = "2020-01-01 00:00:00";
+            String endTime = LocalDateTime.now().plusDays(-3).format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
+            Page<BaseCaseVO> page = baseCaseService.selectVideoInspection(i, 10, null, null, beginTime, endTime, null);
+
+            System.out.println("----------------娓呴櫎鏁版嵁浠诲姟鎬绘潯鏁�:" + page.getTotal());
+            if (page.getRecords().size() > 0) {
+                page.getRecords().forEach(baseCaseVO -> {
+                    String picData = baseCaseVO.getPicData();
+                    String[] urls = picData.split(",");
+                    for (String url : urls) {
+                        try {
+                            ossService.deleteImages(url);
+                        } catch (UnsupportedEncodingException e) {
+                            throw new RuntimeException(e);
+                        }
+                    }
+                    baseCaseService.removeById(baseCaseVO.getBaseId());
+                    imageService.removeById(baseCaseVO.getImageId());
+
+                    System.out.println("----------------娓呴櫎鏁版嵁鏁版嵁鎴愬姛锛宨d:" + baseCaseVO.getBaseId());
+                });
+            } else {
+                break;
+            }
+            i++;
+        }
+    }
 }
diff --git a/ycl-platform/src/main/java/com/ycl/util/SpringContextUtil.java b/ycl-platform/src/main/java/com/ycl/util/SpringContextUtil.java
new file mode 100644
index 0000000..5a4749b
--- /dev/null
+++ b/ycl-platform/src/main/java/com/ycl/util/SpringContextUtil.java
@@ -0,0 +1,17 @@
+package com.ycl.util;
+
+import org.springframework.context.ApplicationContext;
+
+public class SpringContextUtil {
+    private static ApplicationContext ac;
+
+    public static <T> T getBean(String beanName, Class<T> clazz) {
+        T bean = ac.getBean(beanName, clazz);
+        return bean;
+    }
+
+    public static void setAc(ApplicationContext applicationContext) {
+        ac = applicationContext;
+    }
+
+}
diff --git a/ycl-platform/src/main/java/com/ycl/vo/casePool/BaseCaseVO.java b/ycl-platform/src/main/java/com/ycl/vo/casePool/BaseCaseVO.java
index 62cf9b9..32e7bb2 100644
--- a/ycl-platform/src/main/java/com/ycl/vo/casePool/BaseCaseVO.java
+++ b/ycl-platform/src/main/java/com/ycl/vo/casePool/BaseCaseVO.java
@@ -15,6 +15,7 @@
     private String longitude;
     private String latitude;
     private String picData;
+    private Integer imageId;
     private String grade;
     private String address;
     private String algoName;
diff --git a/ycl-platform/src/main/resources/application-dev.yml b/ycl-platform/src/main/resources/application-dev.yml
index 4dd418e..8919cba 100644
--- a/ycl-platform/src/main/resources/application-dev.yml
+++ b/ycl-platform/src/main/resources/application-dev.yml
@@ -1,5 +1,5 @@
 server:
-  port: 28082
+  port: 8082
   tomcat:
     uri-encoding: UTF-8
   servlet:
@@ -82,10 +82,11 @@
 
 aliyun:
   oss:
-    endpoint: https://oss-accelerate.aliyuncs.com
+    endpoint: https://oss-cn-shenzhen.aliyuncs.com
     keyId: LTAIDlTWjHW0IVyW
     keySecret: 6fO78NmgyF49TK5GWFAzXuSAexl9PL
     bucketName: xshlivelesson
+    prefixUrl: https://xshlivelesson.oss-cn-shenzhen.aliyuncs.com/
 
 #涓撴湁閽夐拤鍙傛暟
 zzding :
diff --git a/ycl-platform/src/main/resources/application-prod.yml b/ycl-platform/src/main/resources/application-prod.yml
index ce662ad..743008f 100644
--- a/ycl-platform/src/main/resources/application-prod.yml
+++ b/ycl-platform/src/main/resources/application-prod.yml
@@ -86,6 +86,8 @@
     keyId: Tkf72Q1gdzETsZf6
     keySecret: tRk39S6B1kSGARRdS4DF6jxr5nBYj5
     bucketName: zhzfptoss
+    # 鍘烵SS鍦板潃澶�
+    prefixUrl: http://zhzfptoss.oss-cn-zjls-lszwy-d01-a.ops.zjlscloud.com/
 
 #涓撴湁閽夐拤鍙傛暟
 zzding :
@@ -93,4 +95,7 @@
   app-secret : 0GPY3aQDL3l38J7p6K37DV6BCXIOLzrynU71Br36
   domain-name : openplatform-pro.ding.zj.gov.cn
   protocal : https
-  tenant-id : 196729
\ No newline at end of file
+  tenant-id : 196729
+mybatis-plus:
+  configuration:
+    log-impl: org.apache.ibatis.logging.nologging.NoLoggingImpl
diff --git a/ycl-platform/src/main/resources/mapper/caseHandler/BaseCaseMapper.xml b/ycl-platform/src/main/resources/mapper/caseHandler/BaseCaseMapper.xml
index 5a4f79d..1d1099d 100644
--- a/ycl-platform/src/main/resources/mapper/caseHandler/BaseCaseMapper.xml
+++ b/ycl-platform/src/main/resources/mapper/caseHandler/BaseCaseMapper.xml
@@ -278,6 +278,7 @@
         t3.longitude,
         t3.latitude,
         t4.pic_data,
+        t4.id as imageId,
         t5.`name` as grade,
         t3.address,
         t3.plat_resource_id as platResourceId,
diff --git a/ycl-platform/src/test/java/com/ycl/sccgplatform/Test1.java b/ycl-platform/src/test/java/com/ycl/sccgplatform/Test1.java
index 148d96b..58f9ca9 100644
--- a/ycl-platform/src/test/java/com/ycl/sccgplatform/Test1.java
+++ b/ycl-platform/src/test/java/com/ycl/sccgplatform/Test1.java
@@ -8,13 +8,17 @@
 import com.aliyun.oss.common.auth.EnvironmentVariableCredentialsProvider;
 import com.aliyun.oss.common.comm.SignVersion;
 import com.aliyuncs.exceptions.ClientException;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.dahua.netsdk.lib.callback.impl.AnalyzerDataCB;
 import com.ycl.common.util.UtilNumber;
 import com.ycl.entity.dingding.DingUserInfo;
 import com.ycl.entity.user.UmsAdmin;
 import com.ycl.mapper.unlawful.UnlawfulMapper;
+import com.ycl.service.caseHandler.IBaseCaseService;
+import com.ycl.service.caseHandler.IViolationsService;
 import com.ycl.service.oss.OssService;
 import com.ycl.utils.ConstantPropertiesUtils;
+import com.ycl.vo.casePool.BaseCaseVO;
 import net.coobird.thumbnailator.Thumbnails;
 import org.junit.jupiter.api.Test;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -26,6 +30,8 @@
 import java.io.*;
 import java.net.HttpURLConnection;
 import java.net.URL;
+import java.time.LocalDateTime;
+import java.time.format.DateTimeFormatter;
 import java.util.*;
 
 @ComponentScan("com.dahua.netsdk")
@@ -33,7 +39,13 @@
 public class Test1 {
 
     @Autowired
+    private IBaseCaseService baseCaseService;
+
+    @Autowired
     private OssService ossService;
+
+    @Autowired
+    private IViolationsService violationsService;
 
     @Resource
     private UnlawfulMapper unlawfuldao;
@@ -42,7 +54,7 @@
 
     @Test
     void test() {
-        String fileUrl = "https://huachuang-resource.oss-cn-beijing.aliyuncs.com/瀹跺涵鏁欒偛/涓浗闄惰鐭ュ崗浼氬搴暀鑲蹭笓濮斾細.doc?Expires=1738857178&OSSAccessKeyId=LTAIxtcfDe3fgfcf&Signature=wTwx6JA6VWbPB0skVySy9MCexog=";
+        String fileUrl = "https://xshlivelesson.oss-cn-shenzhen.aliyuncs.com/2.pptx?Expires=1738857178&OSSAccessKeyId=LTAIxtcfDe3fgfcf&Signature=wTwx6JA6VWbPB0skVySy9MCexog=";
         // http://zhzfptoss.oss-cn-zjls-lszwy-d01-a.ops.zjlscloud.com/sczf/2023062950465224.jpg?Expires=2634106907&OSSAccessKeyId=Tkf72Q1gdzETsZf6&Signature=ttME%2BeFhss8wPbkRCxAsV%2FPNWGQ%3D
 
         OSS ossClient = null;
@@ -55,10 +67,8 @@
 
             String[] urlArray = fileUrl.split("Expires=");
 
-            String[] urlArray2 = urlArray[0].split("aliyuncs.com/");
-
-            String objectName = urlArray2[1].replace("?", "");
-
+            String objectName = urlArray[0].replace(ConstantPropertiesUtils.PREFIX_URL, "");
+            objectName = objectName.replace("?", "");
 
             ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
 
@@ -207,7 +217,7 @@
 //    AnalyzerDataCB analyzerDataCB;
 
     @Test
-    void alarmTest() {
+    void alarmTest() throws UnsupportedEncodingException {
 
 //        analyzerDataCB.invoke(null, 0, null, null, 0, null, 0, null);
 
@@ -220,6 +230,35 @@
 //        AlarmListenModule.startListen(cbMessage);
 //
 //        System.out.println(cbMessage.data);
+
+        //  https://xshlivelesson.oss-accelerate.aliyuncs.com/sczf/2025-02-28%2015%3A53%3A293732..JPG?Expires=2686809213&OSSAccessKeyId=LTAIDlTWjHW0IVyW&Signature=Q5WO2kQcWRpq0SQiYjBCo6rGyJE%3D"
+
+        ossService.deleteImages("https://xshlivelesson.oss-cn-shenzhen.aliyuncs.com/sczf/2025022845414037.JPG?Expires=2686811218&OSSAccessKeyId=LTAIDlTWjHW0IVyW&Signature=5SQ7PInLkbd62zJ1aurljeO0c%2Bw%3D");
+
+        int i = 1;
+        while (true) {
+            String beginTime = "2025-01-01 00:00:00";
+            String endTime = LocalDateTime.now().plusDays(-4).format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
+            Page<BaseCaseVO> page = baseCaseService.selectVideoInspection(i, 10, null, null, beginTime, endTime, null);
+            if (page.getRecords().size() > 0) {
+                page.getRecords().forEach(baseCaseVO -> {
+                    String picData = baseCaseVO.getPicData();
+                    String[] urls = picData.split(",");
+                    for (String url : urls) {
+                        try {
+                            ossService.deleteImages(url);
+                        } catch (UnsupportedEncodingException e) {
+                            throw new RuntimeException(e);
+                        }
+                    }
+                    baseCaseService.removeById(baseCaseVO.getBaseId());
+                    violationsService.removeById(baseCaseVO.getBaseId());
+                });
+            } else {
+                break;
+            }
+            i++;
+        }
     }
 
 
diff --git a/ycl-smoke/pom.xml b/ycl-smoke/pom.xml
index f7cdd77..aa8e8b2 100644
--- a/ycl-smoke/pom.xml
+++ b/ycl-smoke/pom.xml
@@ -30,12 +30,12 @@
             <artifactId>spring-boot-starter-test</artifactId>
             <scope>test</scope>
         </dependency>
-        <dependency>
-            <groupId>com.ycl</groupId>
-            <artifactId>ycl-generator</artifactId>
-            <version>1.0.0</version>
-            <scope>compile</scope>
-        </dependency>
+<!--        <dependency>-->
+<!--            <groupId>com.ycl</groupId>-->
+<!--            <artifactId>ycl-generator</artifactId>-->
+<!--            <version>1.0.0</version>-->
+<!--            <scope>compile</scope>-->
+<!--        </dependency>-->
     </dependencies>
 
     <!--    <build>-->

--
Gitblit v1.8.0