refactor(接口定义): 操作历史代码优化
This commit is contained in:
parent
66abe978fe
commit
60f41171b2
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.dff;
|
||||
package io.metersphere.log.utils;
|
||||
|
||||
import com.alibaba.fastjson.JSON;
|
||||
import com.alibaba.fastjson.JSONObject;
|
||||
|
@ -7,9 +7,8 @@ import io.metersphere.api.dto.definition.request.sampler.MsHTTPSamplerProxy;
|
|||
import io.metersphere.api.dto.definition.request.sampler.MsJDBCSampler;
|
||||
import io.metersphere.api.dto.definition.request.sampler.MsTCPSampler;
|
||||
import io.metersphere.api.dto.scenario.Body;
|
||||
import io.metersphere.log.utils.ReflexObjectUtil;
|
||||
import io.metersphere.log.utils.json.diff.JacksonDiff;
|
||||
import io.metersphere.log.utils.json.diff.JsonDiff;
|
||||
import io.metersphere.log.utils.diff.json.JacksonDiff;
|
||||
import io.metersphere.log.utils.diff.json.JsonDiff;
|
||||
import io.metersphere.log.vo.DetailColumn;
|
||||
import io.metersphere.log.vo.OperatingLogDetails;
|
||||
import io.metersphere.log.vo.api.DefinitionReference;
|
||||
|
@ -21,8 +20,8 @@ import java.util.List;
|
|||
import java.util.Map;
|
||||
|
||||
public class ApiDefinitionDiffUtil {
|
||||
static final String JSON_START = "{\"root\":";
|
||||
static final String JSON_END = "}";
|
||||
public static final String JSON_START = "{\"root\":";
|
||||
public static final String JSON_END = "}";
|
||||
|
||||
public static String diffResponse(String newValue, String oldValue) {
|
||||
Map<String, String> diffMap = new LinkedHashMap<>();
|
|
@ -7,8 +7,7 @@ import com.google.gson.GsonBuilder;
|
|||
import com.google.gson.JsonObject;
|
||||
import io.metersphere.commons.utils.BeanUtils;
|
||||
import io.metersphere.commons.utils.LogUtil;
|
||||
import io.metersphere.log.utils.dff.ApiDefinitionDiffUtil;
|
||||
import io.metersphere.log.utils.json.diff.GsonDiff;
|
||||
import io.metersphere.log.utils.diff.json.GsonDiff;
|
||||
import io.metersphere.log.vo.DetailColumn;
|
||||
import io.metersphere.log.vo.OperatingLogDetails;
|
||||
import io.metersphere.log.vo.StatusReference;
|
||||
|
@ -19,6 +18,7 @@ import java.util.*;
|
|||
import java.util.stream.Collectors;
|
||||
|
||||
public class ReflexObjectUtil {
|
||||
static final Gson gson = new GsonBuilder().setPrettyPrinting().create();
|
||||
|
||||
public static List<DetailColumn> getColumns(Object obj, Map<String, String> columns) {
|
||||
List<DetailColumn> columnList = new LinkedList<>();
|
||||
|
@ -30,7 +30,45 @@ public class ReflexObjectUtil {
|
|||
if (StringUtils.isNotEmpty(dffValue)) {
|
||||
dffColumns = Arrays.asList(dffValue.split(","));
|
||||
}
|
||||
// 得到类对象
|
||||
// 得到类中的所有属性集合
|
||||
List<Field[]> fields = getFields(obj);
|
||||
try {
|
||||
for (Field[] fs : fields) {
|
||||
for (int i = 0; i < fs.length; i++) {
|
||||
Field f = fs[i];
|
||||
f.setAccessible(true);
|
||||
if (columns.containsKey(f.getName())) {
|
||||
Object val = f.get(obj);
|
||||
if (StatusReference.statusMap.containsKey(String.valueOf(val))) {
|
||||
val = StatusReference.statusMap.get(String.valueOf(val));
|
||||
}
|
||||
DetailColumn column = new DetailColumn(columns.get(f.getName()), f.getName(), val, "");
|
||||
if (dffColumns.contains(f.getName())) {
|
||||
column.setDepthDff(true);
|
||||
column.setOriginalValue(formatJson(val));
|
||||
}
|
||||
columnList.add(column);
|
||||
}
|
||||
}
|
||||
}
|
||||
} catch (Exception e) {
|
||||
LogUtil.error(e);
|
||||
}
|
||||
List<String> keys = columns.keySet().stream().collect(Collectors.toList());
|
||||
ReflexObjectUtil.order(keys, columnList);
|
||||
return columnList;
|
||||
}
|
||||
|
||||
static Object formatJson(Object val) {
|
||||
try {
|
||||
JsonObject jsonObject = gson.fromJson(String.valueOf(val), JsonObject.class);
|
||||
return gson.toJson(jsonObject);
|
||||
} catch (Exception e) {
|
||||
return val;
|
||||
}
|
||||
}
|
||||
|
||||
static List<Field[]> getFields(Object obj) {
|
||||
Class clazz = obj.getClass();
|
||||
// 得到类中的所有属性集合
|
||||
List<Field[]> fields = new LinkedList<>();
|
||||
|
@ -42,40 +80,7 @@ public class ReflexObjectUtil {
|
|||
// 获得父类的字节码对象
|
||||
clazz = clazz.getSuperclass();
|
||||
}
|
||||
for (Field[] fs : fields) {
|
||||
for (int i = 0; i < fs.length; i++) {
|
||||
Field f = fs[i];
|
||||
f.setAccessible(true);
|
||||
try {
|
||||
if (columns.containsKey(f.getName())) {
|
||||
Object val = f.get(obj);
|
||||
if (val != null && StatusReference.statusMap.containsKey(val.toString())) {
|
||||
val = StatusReference.statusMap.get(val.toString());
|
||||
}
|
||||
DetailColumn column = new DetailColumn(columns.get(f.getName()), f.getName(), val, "");
|
||||
if (dffColumns.contains(f.getName())) {
|
||||
column.setDepthDff(true);
|
||||
if (val != null) {
|
||||
try {
|
||||
// 格式化
|
||||
Gson gson = new GsonBuilder().setPrettyPrinting().create();
|
||||
JsonObject jsonObject = gson.fromJson(val.toString(), JsonObject.class);
|
||||
column.setOriginalValue(gson.toJson(jsonObject));
|
||||
} catch (Exception e) {
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
columnList.add(column);
|
||||
}
|
||||
} catch (Exception e) {
|
||||
LogUtil.error(e);
|
||||
}
|
||||
}
|
||||
}
|
||||
List<String> keys = columns.keySet().stream().collect(Collectors.toList());
|
||||
ReflexObjectUtil.order(keys, columnList);
|
||||
return columnList;
|
||||
return fields;
|
||||
}
|
||||
|
||||
public static List<DetailColumn> getColumns(Object obj) {
|
||||
|
@ -83,18 +88,8 @@ public class ReflexObjectUtil {
|
|||
if (obj == null) {
|
||||
return columnList;
|
||||
}
|
||||
// 得到类对象
|
||||
Class clazz = obj.getClass();
|
||||
// 得到类中的所有属性集合
|
||||
List<Field[]> fields = new LinkedList<>();
|
||||
// 遍历所有父类字节码对象
|
||||
while (clazz != null) {
|
||||
// 获取字节码对象的属性对象数组
|
||||
Field[] declaredFields = clazz.getDeclaredFields();
|
||||
fields.add(declaredFields);
|
||||
// 获得父类的字节码对象
|
||||
clazz = clazz.getSuperclass();
|
||||
}
|
||||
List<Field[]> fields = getFields(obj);
|
||||
for (Field[] fs : fields) {
|
||||
for (int i = 0; i < fs.length; i++) {
|
||||
Field f = fs[i];
|
||||
|
@ -156,8 +151,8 @@ public class ReflexObjectUtil {
|
|||
column.setNewValue(newColumns.get(i).getOriginalValue());
|
||||
if (StringUtils.isNotEmpty(originalColumns.get(i).getColumnName()) && originalColumns.get(i).getColumnName().equals("tags")) {
|
||||
GsonDiff diff = new GsonDiff();
|
||||
String oldTags = "{\"root\":" + ((originalColumns.get(i) != null && originalColumns.get(i).getOriginalValue() != null) ? originalColumns.get(i).getOriginalValue().toString() : "\"\"") + "}";
|
||||
String newTags = "{\"root\":" + ((newColumns.get(i) != null && newColumns.get(i).getOriginalValue() != null) ? newColumns.get(i).getOriginalValue().toString() : "\"\"") + "}";
|
||||
String oldTags = ApiDefinitionDiffUtil.JSON_START + ((originalColumns.get(i) != null && originalColumns.get(i).getOriginalValue() != null) ? originalColumns.get(i).getOriginalValue().toString() : "\"\"") + ApiDefinitionDiffUtil.JSON_END;
|
||||
String newTags = ApiDefinitionDiffUtil.JSON_START + ((newColumns.get(i) != null && newColumns.get(i).getOriginalValue() != null) ? newColumns.get(i).getOriginalValue().toString() : "\"\"") + ApiDefinitionDiffUtil.JSON_END;
|
||||
String diffStr = diff.diff(oldTags, newTags);
|
||||
String diffValue = diff.apply(newTags, diffStr);
|
||||
column.setDiffValue(diffValue);
|
||||
|
@ -174,7 +169,6 @@ public class ReflexObjectUtil {
|
|||
column.setDiffValue(ApiDefinitionDiffUtil.diffResponse(newValue, oldValue));
|
||||
}
|
||||
} else {
|
||||
try {
|
||||
String newValue = column.getNewValue().toString();
|
||||
if (StringUtils.isNotEmpty(newValue)) {
|
||||
column.setNewValue(newValue.replaceAll("\\n", " "));
|
||||
|
@ -183,9 +177,6 @@ public class ReflexObjectUtil {
|
|||
if (StringUtils.isNotEmpty(oldValue)) {
|
||||
column.setOriginalValue(oldValue.replaceAll("\\n", " "));
|
||||
}
|
||||
} catch (Exception e) {
|
||||
|
||||
}
|
||||
}
|
||||
comparedColumns.add(column);
|
||||
}
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
class ArrNode extends Node {
|
||||
|
|
@ -1,9 +1,9 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
import com.google.gson.JsonElement;
|
||||
import com.google.gson.JsonObject;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.gson.GsonWrapper;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.gson.GsonWrapper;
|
||||
|
||||
public class GsonDiff extends JsonDiff {
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
import java.util.*;
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
/*
|
||||
Copyright (c) 2009, incava.org
|
|
@ -1,6 +1,6 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.jackson.JacksonWrapper;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.jackson.JacksonWrapper;
|
||||
|
||||
public class JacksonDiff extends JsonDiff {
|
||||
|
|
@ -1,12 +1,12 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
import com.google.gson.JsonPrimitive;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonObject;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.Wrapper;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.gson.GsonJsonPrimitive;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.jackson.JacksonJsonObject;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonObject;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.Wrapper;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.gson.GsonJsonPrimitive;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.jackson.JacksonJsonObject;
|
||||
import org.apache.commons.lang3.StringUtils;
|
||||
|
||||
import java.util.*;
|
|
@ -1,9 +1,9 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonObject;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.Wrapper;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonObject;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.Wrapper;
|
||||
|
||||
import java.util.*;
|
||||
import java.util.logging.Level;
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
abstract class Node implements Cloneable {
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
class ObjNode extends Node {
|
||||
|
|
@ -0,0 +1,5 @@
|
|||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
enum Oper {
|
||||
INSERT, DELETE, SET
|
||||
}
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
class Root extends Node {
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
package io.metersphere.log.utils.diff.json;
|
||||
|
||||
|
||||
/**
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap;
|
||||
|
||||
/**
|
||||
* Common abstaraction for a json array.
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap;
|
||||
|
||||
/**
|
||||
* Common abstraction for json elements.
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap;
|
||||
|
||||
/**
|
||||
* Common abstraction for json null.
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.Map.Entry;
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap;
|
||||
|
||||
/**
|
||||
* Common abstraction for json primitive values.
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap;
|
||||
|
||||
/**
|
||||
* Factory wrapper interface for multiple json implementations.
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.gson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.gson;
|
||||
|
||||
import java.lang.reflect.Field;
|
||||
import java.util.ArrayList;
|
||||
|
@ -6,8 +6,8 @@ import java.util.ArrayList;
|
|||
import com.google.gson.JsonArray;
|
||||
import com.google.gson.JsonElement;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
|
||||
public class GsonJsonArray extends GsonJsonElement implements JzonArray {
|
||||
|
|
@ -1,8 +1,8 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.gson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.gson;
|
||||
|
||||
import com.google.gson.JsonElement;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
|
||||
|
||||
public class GsonJsonElement implements JzonElement {
|
|
@ -1,8 +1,8 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.gson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.gson;
|
||||
|
||||
import com.google.gson.JsonNull;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonNull;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonNull;
|
||||
|
||||
|
||||
public class GsonJsonNull extends GsonJsonElement implements JzonNull {
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.gson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.gson;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.HashSet;
|
||||
|
@ -8,8 +8,8 @@ import java.util.Set;
|
|||
import com.google.gson.JsonElement;
|
||||
import com.google.gson.JsonObject;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonObject;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonObject;
|
||||
|
||||
|
||||
public class GsonJsonObject extends GsonJsonElement implements JzonObject {
|
|
@ -1,8 +1,8 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.gson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.gson;
|
||||
|
||||
import com.google.gson.JsonPrimitive;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonPrimitive;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonPrimitive;
|
||||
|
||||
|
||||
public class GsonJsonPrimitive extends GsonJsonElement implements JzonPrimitive {
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.gson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.gson;
|
||||
|
||||
import com.google.gson.JsonArray;
|
||||
import com.google.gson.JsonElement;
|
||||
|
@ -6,10 +6,10 @@ import com.google.gson.JsonObject;
|
|||
import com.google.gson.JsonParser;
|
||||
import com.google.gson.JsonPrimitive;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonObject;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.Wrapper;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.Wrapper;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonObject;
|
||||
|
||||
public class GsonWrapper implements Wrapper {
|
||||
|
|
@ -1,10 +1,10 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.jackson;
|
||||
|
||||
import org.codehaus.jackson.JsonNode;
|
||||
import org.codehaus.jackson.node.ArrayNode;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
|
||||
public class JacksonJsonArray extends JacksonJsonElement implements JzonArray {
|
||||
|
|
@ -1,8 +1,8 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.jackson;
|
||||
|
||||
import org.codehaus.jackson.JsonNode;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
|
||||
|
||||
public class JacksonJsonElement implements JzonElement {
|
|
@ -1,8 +1,8 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.jackson;
|
||||
|
||||
import org.codehaus.jackson.node.NullNode;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonNull;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonNull;
|
||||
|
||||
|
||||
public class JacksonJsonNull extends JacksonJsonElement implements JzonNull {
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.jackson;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.HashSet;
|
||||
|
@ -8,8 +8,8 @@ import java.util.Map.Entry;
|
|||
import org.codehaus.jackson.JsonNode;
|
||||
import org.codehaus.jackson.node.ObjectNode;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonObject;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonObject;
|
||||
|
||||
|
||||
public class JacksonJsonObject extends JacksonJsonElement implements JzonObject {
|
|
@ -1,8 +1,8 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.jackson;
|
||||
|
||||
import org.codehaus.jackson.node.ValueNode;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonPrimitive;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonPrimitive;
|
||||
|
||||
|
||||
public class JacksonJsonPrimitive extends JacksonJsonElement implements JzonPrimitive {
|
|
@ -1,7 +1,8 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.jackson;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.Wrapper;
|
||||
import org.codehaus.jackson.JsonNode;
|
||||
import org.codehaus.jackson.JsonParser;
|
||||
import org.codehaus.jackson.JsonProcessingException;
|
||||
|
@ -10,10 +11,9 @@ import org.codehaus.jackson.node.ArrayNode;
|
|||
import org.codehaus.jackson.node.ObjectNode;
|
||||
import org.codehaus.jackson.node.ValueNode;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonObject;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.Wrapper;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.diff.json.jsonwrap.JzonObject;
|
||||
|
||||
public class JacksonWrapper implements Wrapper {
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson;
|
||||
package io.metersphere.log.utils.diff.json.jsonwrap.jackson;
|
||||
|
||||
@SuppressWarnings("serial")
|
||||
public class JacksonWrapperException extends RuntimeException {
|
|
@ -1,23 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
|
||||
public class DiffTest {
|
||||
public static void main(String[] args) {
|
||||
GsonDiff diff = new GsonDiff();
|
||||
|
||||
String newValue= "{\n" +
|
||||
" \"username\": \"zyy\",\n" +
|
||||
" \"username2\": \"zyy\",\n" +
|
||||
" \"password\": \"Calong@2015\"\n" +
|
||||
"}";
|
||||
String oldValue = "{\n" +
|
||||
" \"username\": \"zyy\",\n" +
|
||||
" \"username1\": \"zyy\",\n" +
|
||||
" \"password\": \"Calong@201512\"\n" +
|
||||
"}";
|
||||
String d = diff.diff(oldValue,newValue);
|
||||
|
||||
System.out.println(d);
|
||||
|
||||
System.out.println(diff.apply(newValue,d));
|
||||
}
|
||||
}
|
|
@ -1,11 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.jackson2.Jackson2Wrapper;
|
||||
|
||||
public class Jackson2Diff extends JsonDiff {
|
||||
|
||||
public Jackson2Diff() {
|
||||
super(new Jackson2Wrapper());
|
||||
}
|
||||
|
||||
}
|
|
@ -1,5 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff;
|
||||
|
||||
enum Oper {
|
||||
INSERT, DELETE, SET
|
||||
}
|
|
@ -1,47 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson2;
|
||||
|
||||
import com.fasterxml.jackson.databind.JsonNode;
|
||||
import com.fasterxml.jackson.databind.node.ArrayNode;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
|
||||
public class Jackson2JsonArray extends Jackson2JsonElement implements JzonArray {
|
||||
|
||||
private final ArrayNode wrapped;
|
||||
|
||||
public Jackson2JsonArray(ArrayNode wrapped) {
|
||||
super(wrapped);
|
||||
this.wrapped = wrapped;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int size() {
|
||||
return wrapped.size();
|
||||
}
|
||||
|
||||
@Override
|
||||
public JzonElement get(int index) {
|
||||
return Jackson2Wrapper.wrap(wrapped.get(index));
|
||||
}
|
||||
|
||||
@Override
|
||||
public void insert(int index, JzonElement el) {
|
||||
wrapped.insert(index, (JsonNode) el.unwrap());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void set(int index, JzonElement el) {
|
||||
wrapped.set(index, (JsonNode) el.unwrap());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void remove(int index) {
|
||||
wrapped.remove(index);
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return wrapped.toString();
|
||||
}
|
||||
|
||||
}
|
|
@ -1,65 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson2;
|
||||
|
||||
|
||||
import com.fasterxml.jackson.databind.JsonNode;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
|
||||
|
||||
public class Jackson2JsonElement implements JzonElement {
|
||||
|
||||
final JsonNode wrapped;
|
||||
|
||||
|
||||
protected Jackson2JsonElement(JsonNode wrapped) {
|
||||
this.wrapped = wrapped;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public boolean isJsonObject() {
|
||||
return wrapped.isObject();
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public boolean isJsonArray() {
|
||||
return wrapped.isArray();
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public boolean isJsonPrimitive() {
|
||||
return wrapped.isValueNode();
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public boolean isJsonNull() {
|
||||
return wrapped.isNull();
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public Object unwrap() {
|
||||
return wrapped;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return wrapped.toString();
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public boolean equals(Object obj) {
|
||||
return wrapped.equals(obj);
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public int hashCode() {
|
||||
return wrapped.hashCode();
|
||||
}
|
||||
|
||||
}
|
|
@ -1,20 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson2;
|
||||
|
||||
|
||||
import com.fasterxml.jackson.databind.node.NullNode;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonNull;
|
||||
|
||||
|
||||
public class Jackson2JsonNull extends Jackson2JsonElement implements JzonNull {
|
||||
|
||||
static final NullNode JNULL = NullNode.getInstance();
|
||||
|
||||
|
||||
public final static Jackson2JsonNull INSTANCE = new Jackson2JsonNull();
|
||||
|
||||
|
||||
public Jackson2JsonNull() {
|
||||
super(JNULL);
|
||||
}
|
||||
|
||||
}
|
|
@ -1,98 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson2;
|
||||
|
||||
import com.fasterxml.jackson.databind.JsonNode;
|
||||
import com.fasterxml.jackson.databind.node.ObjectNode;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonObject;
|
||||
|
||||
import java.util.Collection;
|
||||
import java.util.HashSet;
|
||||
import java.util.Iterator;
|
||||
import java.util.Map.Entry;
|
||||
|
||||
|
||||
public class Jackson2JsonObject extends Jackson2JsonElement implements JzonObject {
|
||||
|
||||
private final ObjectNode wrapped;
|
||||
|
||||
|
||||
public Jackson2JsonObject(ObjectNode wrapped) {
|
||||
super(wrapped);
|
||||
this.wrapped = wrapped;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public boolean has(String key) {
|
||||
return wrapped.has(key);
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void add(String key, JzonElement prop) {
|
||||
wrapped.put(key, (JsonNode) prop.unwrap());
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void addProperty(String key, int prop) {
|
||||
wrapped.put(key, prop);
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public Collection<? extends Entry<String, JzonElement>> entrySet() {
|
||||
|
||||
HashSet<Entry<String, JzonElement>> jset = new HashSet<Entry<String, JzonElement>>();
|
||||
|
||||
for (Iterator<Entry<String, JsonNode>> i = wrapped.fields() ; i.hasNext();) {
|
||||
|
||||
final Entry<String, JsonNode> e = i.next();
|
||||
|
||||
final JzonElement el = Jackson2Wrapper.wrap(e.getValue());
|
||||
|
||||
jset.add(new Entry<String, JzonElement>() {
|
||||
|
||||
@Override
|
||||
public String getKey() {
|
||||
return e.getKey();
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public JzonElement getValue() {
|
||||
return el;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public JzonElement setValue(JzonElement value) {
|
||||
throw new UnsupportedOperationException();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
return jset;
|
||||
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public JzonElement get(String key) {
|
||||
return Jackson2Wrapper.wrap(wrapped.get(key));
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public void remove(String key) {
|
||||
wrapped.remove(key);
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public String toString() {
|
||||
return wrapped.toString();
|
||||
}
|
||||
|
||||
|
||||
}
|
|
@ -1,13 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson2;
|
||||
|
||||
import com.fasterxml.jackson.databind.node.ValueNode;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonPrimitive;
|
||||
|
||||
|
||||
public class Jackson2JsonPrimitive extends Jackson2JsonElement implements JzonPrimitive {
|
||||
|
||||
public Jackson2JsonPrimitive(ValueNode wrapped) {
|
||||
super(wrapped);
|
||||
}
|
||||
|
||||
}
|
|
@ -1,64 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson2;
|
||||
|
||||
import com.fasterxml.jackson.core.JsonParser;
|
||||
import com.fasterxml.jackson.core.JsonProcessingException;
|
||||
import com.fasterxml.jackson.databind.JsonNode;
|
||||
import com.fasterxml.jackson.databind.ObjectMapper;
|
||||
import com.fasterxml.jackson.databind.node.ArrayNode;
|
||||
import com.fasterxml.jackson.databind.node.ObjectNode;
|
||||
import com.fasterxml.jackson.databind.node.ValueNode;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonArray;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonElement;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.JzonObject;
|
||||
import io.metersphere.log.utils.json.diff.jsonwrap.Wrapper;
|
||||
|
||||
import java.io.IOException;
|
||||
|
||||
public class Jackson2Wrapper implements Wrapper {
|
||||
|
||||
private final static ObjectMapper JSON = new ObjectMapper();
|
||||
|
||||
public static JzonElement wrap(JsonNode el) {
|
||||
if (el == null || el.isNull()) {
|
||||
return Jackson2JsonNull.INSTANCE;
|
||||
} else if (el.isArray()) {
|
||||
return new Jackson2JsonArray((ArrayNode) el);
|
||||
} else if (el.isObject()) {
|
||||
return new Jackson2JsonObject((ObjectNode) el);
|
||||
} else if (el.isValueNode()) {
|
||||
return new Jackson2JsonPrimitive((ValueNode) el);
|
||||
} else {
|
||||
throw new IllegalStateException();
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public JzonElement parse(String json) {
|
||||
try {
|
||||
JsonParser parser = JSON.getJsonFactory().createJsonParser(json);
|
||||
parser.configure(JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES, true);
|
||||
parser.configure(JsonParser.Feature.ALLOW_SINGLE_QUOTES, true);
|
||||
return wrap(parser.readValueAsTree());
|
||||
} catch (JsonProcessingException e) {
|
||||
throw new Jackson2WrapperException("Failed to parse JSON", e);
|
||||
} catch (IOException e) {
|
||||
throw new Jackson2WrapperException("IOException parsing a String?", e);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public JzonElement wrap(Object o) {
|
||||
return wrap((JsonNode) o);
|
||||
}
|
||||
|
||||
@Override
|
||||
public JzonObject createJsonObject() {
|
||||
return (JzonObject) wrap(JSON.createObjectNode());
|
||||
}
|
||||
|
||||
@Override
|
||||
public JzonArray createJsonArray() {
|
||||
return (JzonArray) wrap(JSON.createArrayNode());
|
||||
}
|
||||
|
||||
}
|
|
@ -1,22 +0,0 @@
|
|||
package io.metersphere.log.utils.json.diff.jsonwrap.jackson2;
|
||||
|
||||
@SuppressWarnings("serial")
|
||||
public class Jackson2WrapperException extends RuntimeException {
|
||||
|
||||
public Jackson2WrapperException() {
|
||||
super();
|
||||
}
|
||||
|
||||
public Jackson2WrapperException(String message, Throwable cause) {
|
||||
super(message, cause);
|
||||
}
|
||||
|
||||
public Jackson2WrapperException(String message) {
|
||||
super(message);
|
||||
}
|
||||
|
||||
public Jackson2WrapperException(Throwable cause) {
|
||||
super(cause);
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in New Issue