FastJson:Json树的CRUD操作方法实现
准备工作:json字符串
[{
"id": 1,
"code": "FLOW_NODE_1",
"name": "环节A",
"children": [{
"id": 2,
"code": "RULE_NODE_1",
"name": "规则A"
}, {
"id": 3,
"code": "RULE_NODE_2",
"name": "规则B"
}, {
"id": 4,
"code": "PARALLEL_NODE_2",
"name": "并行节点",
"children": [{
"id": 5,
"code": "RULE_NODE_3",
"name": "规则C1"
}, {
"id": 6,
"code": "RULE_COLLECTION_1",
"name": "规则集1",
"children": [{
"id": 7,
"code": "RULE_NODE_4",
"name": "规则C21"
}, {
"id": 8,
"code": "RULE_NODE_5",
"name": "规则C22"
}]
}]
}, {
"id": 9,
"code": "MUTUAL_NODE_1",
"name": "互斥节点",
"children": [{
"id": 10,
"code": "RULE_NODE_6",
"name": "规则D1"
}, {
"id": 11,
"code": "RULE_NODE_7",
"name": "规则D2"
}]
}]
}, {
"id": 12,
"code": "FLOW_NODE_2",
"name": "环节B" }]
这里使用的springboot下FastJson下的API使用例子:
步骤一:加入依赖
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>${fastjson.version}</version>
</dependency>
步骤二:
parse方法的使用:例如把JSON文本parse为JSONObject或者JSONArray
更多参考:https://www.cnblogs.com/sunp823/p/5601399.html
1.根据json树treeId查找json并返回给前端:
controller:
/**
* @param treeId
* @return
*/
@ApiOperation(value="查询树信息", notes="查询树信息")
@RequestMapping(value = "/api/v1/orders/findTree" ,method = RequestMethod.POST)
public Map findTree(@ApiParam(required = true, value = "树id") @RequestParam Integer treeId
){
return ActionHelper.responseOk(categoryTreeService.getJsonTree(treeId));
}
service:
//根据id获取json树
public JSONArray getJsonTree(Integer treeId){
JSONArray jsonTree = JSONArray.parseArray(categoryTreeRepository.selectJsonTree(treeId));
return jsonTree;
}
2.查找指定treeId的json树下对应的key-value的节点信息
controller:
/**
* @param treeId 树id
* @param key key名称
* @param value value值
* @return
*/
@ApiOperation(value="查询节点信息", notes="查询节点信息")
@RequestMapping(value = "/api/v1/orders/findNode" ,method = RequestMethod.POST)
public Map findNode(@ApiParam(required = true, value = "树id") @RequestParam Integer treeId,
@ApiParam(required = true, value = "节点key") @RequestParam String key,
@ApiParam(required = true, value = "节点value") @RequestParam String value
){
return ActionHelper.responseOk(categoryTreeService.getNode(treeId,key,value));
}
service:
//根据节点key-value键值对,获取树下该节点信息
public JSONObject getNode(Integer treeId,String key,String value){
JSONArray jsonTree = JSONArray.parseArray(categoryTreeRepository.selectJsonTree(treeId));
JSONObject node = getNode(jsonTree, key, value,new JSONObject());
return node;
} /**
* 根据单一条件获取节点位置
* @param body 查询目标的主体内容
* @param key 筛选匹配条件条件对应--key
* @param value 筛选匹配条件对应--value
* @param result 缓存查询结果
* @return
*/
public static JSONObject getNode(JSONArray body,String key,Object value,JSONObject result) {
for (int i = 0; i < body.size(); i++) {
JSONObject jsonObject =body.getJSONObject(i);
if (jsonObject.get(key).toString().equals(value.toString())) {
for (Map.Entry<String, Object> entry : jsonObject.entrySet()) {
result.put(entry.getKey(), entry.getValue());
}
}else if(jsonObject.getJSONArray("children")!=null) {
getNode(jsonObject.getJSONArray("children"), key, value,result);
}
}
return result;
}
3.删除指定treeId下的指定key-value的节点
controller:
@ApiOperation(value="删除节点信息", notes="删除节点信息")
@RequestMapping(value = "/api/v1/orders/deldNode" ,method = RequestMethod.POST)
public Map delNode(@ApiParam(required = true, value = "树id") @RequestParam Integer treeId,
@ApiParam(required = true, value = "节点key") @RequestParam String key,
@ApiParam(required = true, value = "节点value") @RequestParam String value
){
return ActionHelper.responseOk(categoryTreeService.delNode(treeId,key,value));
}
service:
//删除json树下指定的节点及其子节点
public JSONObject delNode(Integer treeId,String key,String value){
JSONArray jsonTree = JSONArray.parseArray(categoryTreeRepository.selectJsonTree(treeId));
JSONObject node = getNode(jsonTree, key, value,new JSONObject());
delNode(jsonTree, key, value);
String a=jsonTree.toString();
categoryTreeRepository.updateTree(a,treeId);
return node;
} /**
* 根据单一条件删除节点
* @param body 需要删除的目标主体
* @param key 筛选匹配条件对应的key
* @param value 筛选匹配条件对应的value
*/
public void delNode(JSONArray body,String key,Object value) {
for (int i = 0; i < body.size(); i++) {
JSONObject jsonObject =body.getJSONObject(i);
if (jsonObject.get(key).toString().equals(value.toString())) {
Object obj= body.remove(i);
break;
}else if(jsonObject.getJSONArray("children")!=null) {
delNode(jsonObject.getJSONArray("children"), key, value);
}
} }
mapper:
public interface CategoryTreeRepository extends JpaRepository<CategoryTree,String>, JpaSpecificationExecutor<CategoryTree> {
//根据id获取json树字符串
@Query(value="SELECT jsonTree from catagory_tree where id=?1",nativeQuery=true)
String selectJsonTree(Integer id); @Modifying
@Transactional
@Query(value="UPDATE catagory_tree SET jsonTree = ?1 WHERE id = ?2",nativeQuery = true)
void updateTree(String jsonTreeStr,Integer id); }
4.在指定的key-value键值对节点下面添加节点,
目的:children的value为JsonArray格式,在此属性下添加JsonObject节点
依旧走步骤2判断节点是否存在,若存在则:
1.判断此节点下是否存在key为children的属性:
2.如果此节点存在key为children的属性,则在children下指定下标添加节点
3.如果不存在key为children的属性,则添加children,新节点存进children
controller:
@ApiOperation(value="新建节点", notes="根据输入参数创建节点")
@RequestMapping(value = "/tree_data/node/{treeId}", method = RequestMethod.POST)
public Map addOne(@ApiParam(required = true, value = "分类树ID")@PathVariable Integer treeId,
@ApiParam(required = true, value = "节点key") @RequestParam String key,
@ApiParam(required = true, value = "节点value") @RequestParam String value,
@ApiParam(required = true, value = "插入下标") @RequestParam Integer index,
@ApiParam(required = true, value = "节点信息") @RequestBody Map map){
return ActionHelper.responseOk(categoryTreeService.addNode(treeId,key,value,index,map));
}
service:
//在json树下添加节点:
public JSONArray addNode(Integer treeId,String key,Object value,Integer sequ,Map newNodeMap){
JSONArray jsonTree = JSONArray.parseArray(categoryTreeRepository.selectJsonTree(treeId));
Integer nodeId = (Integer)newNodeMap.get("id");
JSONObject node = getNode(jsonTree, "id", nodeId,new JSONObject());
System.out.println(node);
if(!node.isEmpty()){
throw new BadRequestException("此id的节点已存在");
}
//把map转化为JSONObject
JSONObject newNode = new JSONObject(newNodeMap);
addNode(jsonTree,key,value,sequ, newNode);
return jsonTree;
} /**
* 增加节点
* @param jsonArray 需要更新的目标主体
* @param node 增加节点信息
* @param sequ 数组的位置
* @param key 目标主体中的字段名key
* @param value 节点信息与key对应的value
*/
public void addNode(JSONArray jsonArray, String key, Object value, Integer sequ,JSONObject node) {
for (Object obj : jsonArray) {
JSONObject jsonObject = (JSONObject) obj;
JSONArray children = jsonObject.getJSONArray("children");
if (children != null) {
if (value.toString().equals(jsonObject.get(key).toString())) {
if(sequ > children.size()){
//如果下标大于此节点children的长度,则追加
children.add(children.size(), node);
}else{
//在指定位置增加
children.add(sequ-1, node);
}
return;
}
addNode(children,key,value,sequ,node);
} else {
//直接判断是否要在此节点下增加个名为children键值对
if (value.toString().equals(jsonObject.get(key).toString())) {
JSONArray array = new JSONArray();
array.add(node);
jsonObject.put("children", array);
return;
}
}
}
}
5.根据节点id更改节点属性:
涉及API:jsonObject.put(key,value)
依旧先走步骤2查询节点是否存在,若存在则更改属性:
如果更改的属性存在,则覆盖
如果更改的属性不存在,则追加
controller:
@ApiOperation(value="更新节点信息", notes="更新节点信息")
@RequestMapping(value = "/tree_data/node/{treeId}/{id}", method = RequestMethod.PATCH)
public Map updateOne(@ApiParam(required = true, value = "分类树ID")@PathVariable Integer treeId,
@ApiParam(required = true, value = "节点ID")@PathVariable Integer id,
@ApiParam(required = true, value = "节点信息") @RequestBody Map map){
return ActionHelper.responseOk(categoryTreeService.updateNode(treeId,id,map));
}
service:
/**
* 修改单个节点
* @param treeId
* @param nodeId
* @param map
* @return
*/
@Transactional
public JSON updateNode(Integer treeId, Integer nodeId, Map map) {
JSONArray jsonTree = JSONArray.parseArray(categoryTreeRepository.selectJsonTree(treeId));
//查询节点是否存在
if(!getNode(jsonTree, "id", nodeId,new JSONObject()).isEmpty()){
update(jsonTree, "id", nodeId, map);
//更新数据库
String a=jsonTree.toString();
categoryTreeRepository.updateTree(a,treeId);
}else{
throw new BadRequestException("此id的节点不存在");
}
return jsonTree; } /**
* 根据条件更新节点
* @param jsonArray 需要更新的目标主体
* @param key 目标主体中的字段名key
* @param value 更新节点信息与key对应的value
* @param map 更新节点信息
*/
public void update(JSONArray jsonArray, String key, Object value, Map<String,Object> map) {
for (int i = 0; i < jsonArray.size() ; i++) {
JSONObject json=jsonArray.getJSONObject(i);
if(value.toString().equals(json.get(key).toString())){
for (Map.Entry<String,Object> entry : map.entrySet()) {
json.put(entry.getKey(),entry.getValue());
}
break;
}else if(json.getJSONArray("children")!=null) {
update(json.getJSONArray("children"), key, value,map);
}
}
}
FastJson:Json树的CRUD操作方法实现的更多相关文章
- JSON树节点的增删查改
最近了解到使用json字符串存到数据库的一种存储方式,取出来的json字符串可以进行相应的节点操作 故借此机会练习下递归,完成对json节点操作对应的工具类. 介绍一下我使用的依赖 复制代码 < ...
- jquery: json树组数据输出到表格Dom树的处理方法
项目背景 项目中需要把表格重排显示 处理方法 思路主要是用历遍Json数组把json数据一个个append到5个表格里,还要给每个单元格绑定个单击弹出自定义对话框,表格分了单双行,第一行最后还要改ro ...
- com.alibaba.fastjson.JSON对类对象的序列化与反序列化
1. 目标 把类的对象存储到字符串可存储 2. 类定义 public interface JsonInterface { } mport com.alibaba.fastjson.JSON; impo ...
- json树递归js查询json父子节点
上代码,直接另存为html打开,看console控制台就可以看到效果了 <!DOCTYPE html> <html lang="en"> <head& ...
- 递归遍历JSON树
递归遍历JSON树 前几天有个人问我,json串的层级无限深,但在json串中的key是已知的,在json串中的value,有些事Object,有些是Array,如何把这些层级无限深的key所对应的v ...
- (转载)JavaScript递归查询 json 树 父子节点
在Json中知道某个属性名,想要确定该属性在Json树具体的节点,然后进行操作还是很麻烦的 可以用以下方法找到该属性所在的节点,和父节点 <!DOCTYPE html> <html ...
- Vue之使用JsonView来展示Json树
前两天干活儿有个需求,在前端需要展示可折叠的Json树,供开发人员查看,这里采用JsonView组件来实现,它是一款用于展示Json的Vue组件,支持大体积的Json文件快速解析渲染,下面记录一下实现 ...
- com.alibaba.fastjson.JSON.parseObject
Journal 日志实体 Journal journal = com.alibaba.fastjson.JSON.parseObject(jsonStr, new com.alibaba.fastjs ...
- fastjson JSON.toJavaObject() 实体类首字母大写属性无法解析问题
fastjson JSON.toJavaObject() 实体类首字母大写属性无法解析问题
随机推荐
- [加密解密]CryptoAPI简介
CryptoAPI概述 Windows CryptoAPI是Microsoft 公司提出的安全加密应用服务框架,也是PKI推荐使用的加密 API.它提供了在Win32 环境下使用认证.编码.加密和签名 ...
- JS高德地图计算两地之间的实际距离
这个是通过导航的方式来获取两地之间的实际距离,和消耗的时间(key值自己去申请哈) <!doctype html> <html> <head> <meta c ...
- iOS -- Effective Objective-C 阅读笔记 (6)
1: 在 既有类中使用 关联对象存放自定义数据 有时候需要在对象中存放相关信息, 这是我们经常会从对象所属的类中继承一个子类, 然后改用这个子类对象, 然而并非所有的情况下都能这么做, 有时候类的实 ...
- Token令牌管理权限
什么是token HTTP是一种无状态的协议,也就是HTTP没法保存客户端的信息,没办法区分每次请求的不同. Token是服务器生成的一串字符,作为客户端请求的令牌.当第一次登陆后,服务器会分发Ton ...
- youtube-dl下载youtube视频时查看分辨率以及选择分辨率下载
1.查看分辨率: youtube-dl -F https://www.youtube.com/watch?v=_NMf1TpiFwY 2.根据分辨率下载,比如下载1280*720的mp4,前面的数字是 ...
- Redis在CentOS和Windows安装过程
redis是一种key-value高效的内存数据库. key-value是什么?json懂吧?字典懂吧?这些都是key-value结构的数据,每个key对应1个value. 那这个数据库和我们网站在使 ...
- php正则验证车牌格式的函数
/** * 判断是否合法车牌号 * @name isCarLicense * @param $license * @return bool */ function isCarLicense($lice ...
- spring security 简单应用
Pom <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http:// ...
- getOrderValue 排序 sql server
GO -- =============================================-- Author: <Author,,rx.tang>-- Creat ...
- 怎样设置高效的IIS
适用的IIS版本:IIS 7.0, IIS 7.5, IIS 8.0 适用的Windows版本:Windows Server 2008, Windows Server 2008 R2, Windows ...