登录
首页 >  文章 >  java教程

JavaJsonPath匹配花括号路径技巧

时间:2026-03-12 11:54:46 457浏览 收藏

本文揭秘了在Java中精准定位JSON中所有值包含花括号({ 和 })字段路径的实用方案——针对模板化JSON(如含 {$.field} 占位符的配置)无法被原生JsonPath有效识别的痛点,创新性地采用轻量高效的Josson库,通过flatten深度展平、entries键值展开、正则.*\\{.*}.*内容过滤及路径拼接四步联动,一行链式表达式即可输出标准JSONPath格式的完整匹配路径列表,兼具高可读性、强扩展性与生产级稳定性,让JSON内容驱动的动态路径发现真正落地可行。

Java中使用JsonPath结合正则匹配提取含花括号的JSON路径

本文介绍如何在Java中精准提取JSON中所有值包含 { 和 } 的字段路径,使用Josson库实现高效、可读性强的路径遍历与正则筛选,弥补原生JsonPath对动态内容匹配能力的不足。

本文介绍如何在Java中精准提取JSON中所有**值包含 `{` 和 `}` 的字段路径**,使用Josson库实现高效、可读性强的路径遍历与正则筛选,弥补原生JsonPath对动态内容匹配能力的不足。

在处理模板化JSON(如含占位符 {$.field} 或 {$.description} 的配置文件)时,常需定位所有嵌入了JSON路径表达式的字段——这些字段值通常以 { 开头、} 结尾(或中间包含)。标准 JsonPath(如 Jayway JsonPath)虽支持路径查询和基础过滤,但不支持对节点值内容进行正则匹配并反向获取其路径;其 Option.AS_PATH_LIST 仅作用于显式路径表达式(如 $.foo.*),无法满足“扫描全树 + 值匹配 + 返回路径”的需求。

此时,推荐采用轻量、专为JSON转换设计的 Josson 库。它提供链式函数式语法,天然支持深度遍历、键值对展开、正则过滤及路径拼接,代码简洁且语义清晰。

✅ 解决方案:使用 Josson 提取含 {} 的字段路径

首先添加 Maven 依赖:

<dependency>
    <groupId>com.octomix.josson</groupId>
    <artifactId>josson</artifactId>
    <version>1.8.2</version>
</dependency>

然后执行以下核心逻辑:

import com.octomix.josson.Josson;
import com.fasterxml.jackson.databind.JsonNode;

String json = "{...}"; // 你的原始JSON字符串
Josson josson = Josson.fromJsonString(json);

JsonNode result = josson.getNode(
    "flatten('.','[%d]')"          // 将嵌套结构展平为扁平键路径(如 "contextData.docType")
        + ".entries()"             // 转为键值对数组:[{"key":"...", "value":"..."}, ...]
        + ".[value=~'.*\\{.*}.*']" // 正则过滤:value 包含至少一个 '{' 和 '}'(注意转义)
        + ".concat('$.', key)"     // 为每个匹配项拼接标准JsonPath前缀
);

// 输出所有匹配路径
result.forEach(node -> System.out.println(node.asText()));

? 正则说明:'.*\\{.*}.*' 中 \\{ 和 } 分别匹配字面量 { 和 };.* 允许前后任意字符,确保捕获如 "{ $.description }"、"{$.contractedServices[*].contractId}" 等常见格式。

✅ 示例输出(对应输入JSON)

运行后将得到完整路径列表(符合 JSONPath 标准语法):

$.description
$.filter
$.contextData.docType
$.contextData.docNumber
$.contextData.organizationName
$.contextData.contractedServices
$.children[0].description
$.children[1].description

该结果完全覆盖问题中期望的路径,并额外准确识别了 children 数组内各元素的 description 字段——这正是深度遍历(flatten)与全量匹配的价值所在。

⚠️ 注意事项与最佳实践

  • 不要尝试用 Jayway JsonPath 原生实现:其 read() 不支持 value =~ regex 类语法,强行使用 ..* 配合 Option.AS_PATH_LIST 仅返回路径,无法关联值内容。
  • Josson 的 flatten() 默认使用 . 作为层级分隔符,若原始JSON键名含 .(极少见),可通过 flatten('#','[%d]') 自定义分隔符。
  • 正则需严格转义:Java字符串中 { 和 } 是正则元字符,必须写为 \\{ 和 \\};若需更精确匹配(如排除 {{}} 等嵌套),可升级为 \\{\\$\\.[^}]+\\}。
  • 性能提示:对于超大JSON(>10MB),建议先验证是否真需全树扫描;若已知范围(如只查 contextData 下),可限定路径:"contextData.*.entries().[value=~'.*\\{.*}.*'].concat('$.contextData.', key)"。

通过 Josson,你获得的不仅是一段工作代码,而是一种面向JSON内容感知的查询范式——让路径发现真正由数据驱动,而非依赖预设结构。

以上就是《JavaJsonPath匹配花括号路径技巧》的详细内容,更多关于的资料请关注golang学习网公众号!

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>