From b0b01b7302d2b9c6b2f5c6583d40b92b63e6b5f1 Mon Sep 17 00:00:00 2001
From: linwei <872216696@qq.com>
Date: Sat, 06 Jun 2026 15:28:58 +0800
Subject: [PATCH] feat(workorder): 添加geojson字段支持并优化数据处理
---
drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/wrapper/GdTaskResultWrapper.java | 63 +++++++++++++++++++++++++++++++
1 files changed, 63 insertions(+), 0 deletions(-)
diff --git a/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/wrapper/GdTaskResultWrapper.java b/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/wrapper/GdTaskResultWrapper.java
index 5e1612c..7d7f468 100644
--- a/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/wrapper/GdTaskResultWrapper.java
+++ b/drone-service/drone-gd/src/main/java/org/sxkj/gd/workorder/wrapper/GdTaskResultWrapper.java
@@ -16,8 +16,11 @@
*/
package org.sxkj.gd.workorder.wrapper;
+import com.alibaba.fastjson.JSON;
+import lombok.extern.slf4j.Slf4j;
import org.springblade.core.mp.support.BaseEntityWrapper;
import org.springblade.core.tool.utils.BeanUtil;
+import org.springblade.core.tool.utils.StringUtil;
import org.sxkj.gd.workorder.dto.GdTaskResultDTO;
import org.sxkj.gd.workorder.entity.GdTaskResultEntity;
import org.sxkj.gd.workorder.vo.GdTaskResultVO;
@@ -32,6 +35,7 @@
* @author lw
* @since 2026-01-14
*/
+@Slf4j
public class GdTaskResultWrapper extends BaseEntityWrapper<GdTaskResultEntity, GdTaskResultVO> {
public static GdTaskResultWrapper build() {
@@ -57,6 +61,7 @@
/**
* 将单个DTO转换为Entity
+ * 处理geojson字段:将字符串数组格式转换为正确的JSON对象数组格式
*
* @param dto DTO对象
* @return Entity对象
@@ -64,16 +69,74 @@
private GdTaskResultEntity convertDtoToEntity(GdTaskResultDTO dto) {
GdTaskResultEntity entity = BeanUtil.copy(dto, GdTaskResultEntity.class);
+ // 步骤1:设置附件类型
if (dto.getAttachmentType() != null) {
entity.setAttachmentType(dto.getAttachmentType());
} else if (dto.getDateType() != null) {
entity.setAttachmentType(dto.getDateType());
}
+ // 步骤2:处理geojson字段,将字符串数组转换为正确的JSON格式
+ String processedGeojson = processGeojson(dto.getGeojson());
+ entity.setGeojson(processedGeojson);
+
return entity;
}
/**
+ * 处理geojson字段,将字符串数组格式转换为正确的JSON对象数组格式
+ * 解决问题:["{\"score\":0.88}"] -> [{"score":0.88}]
+ *
+ * @param geojson 原始geojson字符串
+ * @return 处理后的geojson字符串,如果处理失败则返回原值
+ */
+ private String processGeojson(String geojson) {
+ // 步骤1:空值检查
+ if (StringUtil.isEmpty(geojson)) {
+ return geojson;
+ }
+
+ try {
+ // 步骤2:尝试解析为JSONArray
+ com.alibaba.fastjson.JSONArray jsonArray = JSON.parseArray(geojson);
+ if (jsonArray == null || jsonArray.isEmpty()) {
+ return geojson;
+ }
+
+ // 步骤3:检查第一个元素是否为字符串(说明是字符串数组格式)
+ Object firstElement = jsonArray.get(0);
+ if (firstElement instanceof String) {
+ // 步骤4:这是一个字符串数组,需要解析每个字符串元素
+ com.alibaba.fastjson.JSONArray resultArray = new com.alibaba.fastjson.JSONArray();
+ for (int i = 0; i < jsonArray.size(); i++) {
+ String elementStr = jsonArray.getString(i);
+ if (StringUtil.hasText(elementStr)) {
+ try {
+ // 步骤5:解析字符串为JSON对象
+ com.alibaba.fastjson.JSONObject jsonObj = JSON.parseObject(elementStr);
+ if (jsonObj != null) {
+ resultArray.add(jsonObj);
+ }
+ } catch (Exception e) {
+ // 单个元素解析失败,记录日志但继续处理其他元素
+ log.warn("解析geojson数组元素失败: {}", elementStr);
+ }
+ }
+ }
+ // 步骤6:返回正确的JSON数组格式
+ return resultArray.toJSONString();
+ }
+
+ // 如果不是字符串数组,直接返回原值
+ return geojson;
+ } catch (Exception e) {
+ // 解析失败,返回原值
+ log.warn("处理geojson失败,返回原值: {}", geojson, e);
+ return geojson;
+ }
+ }
+
+ /**
* 将文件类型字符串转换为附件类型编码
*
* @param fileType 文件类型字符串(图片/视频/照片)
--
Gitblit v1.9.3