import com.fasterxml.jackson.databind.JsonNode;
import com.gac.pbi.product.util.JacksonUtil;
import java.util.Optional;
/**
*
* {
* "clsAttrs": [
* {
* "productionCatlogLevel": {
* "name": "品牌名称",
* "brandInternationalName": "品牌别名",
* "states": {
* "code": "停用",
* "cnName": "停用",
* "enName": "disable",
* "alias": "Disable"
* }
* }
* }
* ]
* }
* JsonNode获取json指定key对应value值
*
*/
public class JsonNodeTest {
public static void main(String [] args) {
String json = "{\"clsAttrs\":[{\"productionCatlogLevel\":{\"name\":\"品牌名称\",\"brandInternationalName\":\"品牌别名\",\"states\":{\"code\":\"停用\",\"cnName\":\"停用\",\"enName\":\"disable\",\"alias\":\"Disable\"}}}]}\n";
// 1. 解析JSON为JsonNode,包装成Optional
JsonNode rootNode = JacksonUtil.toJsonNode(json);
Optional<JsonNode> rootOptional = Optional.ofNullable(rootNode);
// 2. 链式调用获取name值,全程无空指针
String name = rootOptional
// 第一步:获取clsAttrs节点(空则返回空Optional)
.map(node -> node.get("clsAttrs"))
// 第二步:判断clsAttrs不是空数组,再取第一个元素
.filter(clsAttrsNode -> !clsAttrsNode.isEmpty())
.map(clsAttrsNode -> clsAttrsNode.get(0))
// 第三步:获取productionCatlogLevel节点
.map(itemNode -> itemNode.get("productionCatlogLevel"))
// 第四步:获取name节点
.map(prodNode -> prodNode.get("name"))
// 第五步:转为字符串(空则返回默认值"")
.map(JsonNode::asText)
// 空值时的默认值
.orElse("");
System.out.println("获取到的name:" + name); // 输出:品牌名称
}
}
JsonNode获取json指定key对应value值
qingcyb2026-03-12 12:42
相关推荐
haven-85214 小时前
AI Agent 生态核心概念详解:Agent、MCP、Skill 与 JSON-RPC_xaboy14 小时前
开源Vue组件FormCreate通过 JSON 生成TinyVue表单yumgpkpm15 小时前
华为HUAWEI昇腾910B下千问Qwen3.6-27B在的推理加速实践SilentSamsara17 小时前
文件与数据处理:CSV/JSON/Excel/Parquet 高效操作与内存优化lzhdim1 天前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析无风听海1 天前
JSON Web Token(JWT)完全指南誰能久伴不乏2 天前
Qt C++ 解析 JSON 完全指南:从核心概念到工业级实战空空潍2 天前
使用Coze工作流API实现结构化输出神奇的代码在哪里2 天前
【单机离线版】excel转json软件,纯HTML+JS零依赖实现Excel转JSON工具,一个index.html搞定所有转换!爱滑雪的码农2 天前
Java基础二十:JSON 数据解析、对象与 JSON 互转逻辑