From 706f722adc849eba0296f1dbd64166e1e0bde4c5 Mon Sep 17 00:00:00 2001 From: liurunyu <lry9898@163.com> Date: 星期二, 14 一月 2025 09:58:41 +0800 Subject: [PATCH] app模块巡检问题上报增加文件处理逻辑,增加缩略图文件路径生成 --- pipIrr-platform/pipIrr-web/pipIrr-web-app/src/main/java/com/dy/pipIrrApp/issue/IssueSv.java | 83 +++++++++++++++++++++++++++++++++++++++-- 1 files changed, 79 insertions(+), 4 deletions(-) diff --git a/pipIrr-platform/pipIrr-web/pipIrr-web-app/src/main/java/com/dy/pipIrrApp/issue/IssueSv.java b/pipIrr-platform/pipIrr-web/pipIrr-web-app/src/main/java/com/dy/pipIrrApp/issue/IssueSv.java index 5787d84..201247d 100644 --- a/pipIrr-platform/pipIrr-web/pipIrr-web-app/src/main/java/com/dy/pipIrrApp/issue/IssueSv.java +++ b/pipIrr-platform/pipIrr-web/pipIrr-web-app/src/main/java/com/dy/pipIrrApp/issue/IssueSv.java @@ -1,24 +1,30 @@ package com.dy.pipIrrApp.issue; +import com.alibaba.fastjson2.JSON; +import com.alibaba.fastjson2.JSONArray; import com.alibaba.fastjson2.JSONObject; +import com.dy.common.util.NumUtil; import com.dy.common.webUtil.QueryResultVo; import com.dy.common.webUtil.ResultCodeMsg; import com.dy.pipIrrApp.issue.dto.DtoDeleteParam; import com.dy.pipIrrApp.issue.qo.QoIssueReport; import com.dy.pipIrrGlobal.daoOp.OpeIssueReportMapper; import com.dy.pipIrrGlobal.daoOp.OpeReportReplyMapper; +import com.dy.pipIrrGlobal.dyFile.FileOperate; +import com.dy.pipIrrGlobal.dyFile.FileRestVo; import com.dy.pipIrrGlobal.pojoOp.OpeIssueReport; import com.dy.pipIrrGlobal.pojoOp.OpeReportReply; import com.dy.pipIrrGlobal.voOp.VoIssueReport; import com.dy.pipIrrGlobal.voOp.VoIssueReportReply; +import com.dy.pipIrrGlobal.voOp.VoIssueReport_temp; import lombok.extern.slf4j.Slf4j; import org.apache.dubbo.common.utils.PojoUtils; +import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; -import java.util.Date; -import java.util.List; -import java.util.Map; +import java.util.*; /** * @author ZhuBaoMin @@ -36,6 +42,29 @@ @Autowired private OpeReportReplyMapper opeReportReplyMapper; + @Value("${dy.webFile.fmUrl}") + private String fmUrl ; + + @Autowired + private FileOperate fileOp ; + + private void dealWebFilePath(JSONArray jsonArray, boolean hasZipFile){ + for (Object obj : jsonArray){ + if(obj instanceof JSONObject){ + JSONObject jsonObject = (JSONObject) obj; + Object hashObj = jsonObject.get("hash") ; + if(hashObj != null && NumUtil.isIntNumber(hashObj.toString())){ + FileRestVo fvo = fileOp.parseHashcode(fmUrl, Integer.valueOf(hashObj.toString())); + if(fvo != null && fvo.fileWebUrl != null){ + jsonObject.put("webPath", fvo.fileWebUrl + jsonObject.get("filePath")); + if(hasZipFile){ + jsonObject.put("webPathZip", fileOp.getFileZipPath(fvo.fileWebUrl + jsonObject.get("filePath"))); + } + } + } + } + } + } /** * 娣诲姞宸℃鍛橀棶棰樹笂鎶� * @param po @@ -74,17 +103,63 @@ Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo); Long itemTotal = opeIssueReportMapper.getIssueReportsCount(params); + //QueryResultVo<List<VoIssueReport_temp>> rsVo = new QueryResultVo<>(); QueryResultVo<List<VoIssueReport>> rsVo = new QueryResultVo<>(); rsVo.pageSize = queryVo.pageSize; rsVo.pageCurr = queryVo.pageCurr; rsVo.calculateAndSet(itemTotal, params); - rsVo.obj = opeIssueReportMapper.getIssueReports(params); + + List<VoIssueReport_temp> list_temp = opeIssueReportMapper.getIssueReports(params); + List<VoIssueReport> list = new ArrayList<>(); + for (int i = 0; i < list_temp.size(); i++) { + VoIssueReport_temp report_temp = list_temp.get(i); + VoIssueReport report = new VoIssueReport(); + BeanUtils.copyProperties(report_temp, report); + + JSONArray images_array = Optional.ofNullable(JSON.parseArray(report_temp.getImages())).orElse(new JSONArray()); + JSONArray audios_array = Optional.ofNullable(JSON.parseArray(report_temp.getAudios())).orElse(new JSONArray()); + JSONArray videos_array = Optional.ofNullable(JSON.parseArray(report_temp.getVideos())).orElse(new JSONArray()); + this.dealWebFilePath(images_array, true) ; + this.dealWebFilePath(audios_array, false) ; + this.dealWebFilePath(videos_array, true) ; + report.setImages(images_array); + report.setAudios(audios_array); + report.setVideos(videos_array); + list.add(report); + } + + rsVo.obj = list; + //rsVo.obj = opeIssueReportMapper.getIssueReports(params); return rsVo; } /** + * 鏍规嵁闂涓婃姤璁板綍涓婚敭鑾峰彇鑾峰彇宸℃鍛橀棶棰樹笂鎶ヨ褰曡鍥惧璞� + * @param issueReportId + * @return + */ + public VoIssueReport getIssueReportById(Long issueReportId) { + VoIssueReport_temp issueReport = opeIssueReportMapper.getIssueReportById(issueReportId); + + VoIssueReport report = new VoIssueReport(); + BeanUtils.copyProperties(issueReport, report); + + JSONArray images_array = Optional.ofNullable(JSON.parseArray(issueReport.getImages())).orElse(new JSONArray()); + JSONArray audios_array = Optional.ofNullable(JSON.parseArray(issueReport.getAudios())).orElse(new JSONArray()); + JSONArray videos_array = Optional.ofNullable(JSON.parseArray(issueReport.getVideos())).orElse(new JSONArray()); + this.dealWebFilePath(images_array, true) ; + this.dealWebFilePath(audios_array, false) ; + this.dealWebFilePath(videos_array, true) ; + + report.setImages(images_array); + report.setAudios(audios_array); + report.setVideos(videos_array); + return report; + } + + /** * 閫昏緫鍒犻櫎宸℃鍛橀棶棰樹笂鎶ワ紝鍒犻櫎鍓嶅厛鍒ゆ柇瑕佸垹闄ょ殑涓婃姤鏄惁瀛樺湪 * @param po * @return -- Gitblit v1.8.0