当前位置: 首页 > article >正文

别再手动解析JSON了!用Jayway JsonPath 2.7.0 + Java,5分钟搞定复杂数据提取

告别JSON解析噩梦Jayway JsonPath在Java中的高效实践JSON作为现代数据交换的事实标准几乎渗透到了每一个Java开发者的日常工作中。无论是微服务间的通信、第三方API的响应还是日志分析中的数据提取我们总在与各种复杂嵌套的JSON结构打交道。传统的手动解析方式不仅代码冗长还容易出错而Jayway JsonPath的出现彻底改变了这一局面。1. 为什么需要JsonPath想象一下这样的场景你需要从一个多层嵌套的JSON响应中提取特定条件下的数据字段。使用传统的Jackson或Gson库你可能需要编写一连串的getter方法和类型检查代码很快就会变得难以维护。而JsonPath提供了一种声明式的查询语言让你能够像使用XPath查询XML那样轻松地定位JSON中的任何节点。JsonPath的核心优势在于简洁性一行表达式替代多层嵌套的对象访问灵活性支持条件过滤、切片操作和复杂路径表达式可读性查询意图直接体现在路径表达式中性能一次解析多次查询减少重复解析开销// 传统方式 vs JsonPath方式对比 // 传统Jackson解析 JsonNode root objectMapper.readTree(json); ListString authors new ArrayList(); for (JsonNode book : root.path(store).path(book)) { authors.add(book.path(author).asText()); } // 使用JsonPath ListString authors JsonPath.read(json, $.store.book[*].author);2. JsonPath核心语法精要JsonPath的语法设计直观而强大掌握几个关键操作符就能应对大多数场景2.1 基础定位操作符$表示文档根节点.或[]访问子节点*通配符匹配所有元素..递归下降搜索所有层级[?(表达式)]过滤器表达式// 实际应用示例 String json ...; // 你的JSON数据 // 获取所有书籍作者 ListString authors JsonPath.read(json, $.store.book[*].author); // 查找价格低于10的书籍 ListMapString, Object cheapBooks JsonPath.read(json, $.store.book[?(.price 10)]); // 获取最后一本书 MapString, Object lastBook JsonPath.read(json, $.store.book[-1:]);2.2 高级过滤技巧JsonPath的过滤表达式支持丰富的比较运算符和逻辑组合// 多条件组合查询 ListMapString, Object results JsonPath.read(json, $.store.book[?(.price 10 .category fiction)]); // 正则表达式匹配 ListMapString, Object regexResults JsonPath.read(json, $.store.book[?(.title ~ /.*of.*/i)]); // 集合包含检查 ListMapString, Object sizeResults JsonPath.read(json, $.store.clothes[?(.sizes anyof [M, L])]);3. Java集成实战Jayway JsonPath提供了与Java生态无缝集成的能力下面我们深入几个实际应用场景。3.1 基础配置与性能优化// Maven依赖 dependency groupIdcom.jayway.jsonpath/groupId artifactIdjson-path/artifactId version2.7.0/version /dependency // 性能关键避免重复解析 Object document Configuration.defaultConfiguration() .jsonProvider() .parse(jsonString); // 多次查询使用同一解析结果 String author1 JsonPath.read(document, $.store.book[0].author); String author2 JsonPath.read(document, $.store.book[1].author);3.2 与Jackson/Gson的深度整合// 配置Jackson集成 Configuration jacksonConfig Configuration.builder() .mappingProvider(new JacksonMappingProvider()) .build(); // 直接映射到POJO Book book JsonPath.using(jacksonConfig) .parse(json) .read($.store.book[0], Book.class); // 处理泛型集合 TypeRefListBook typeRef new TypeRefListBook() {}; ListBook allBooks JsonPath.using(jacksonConfig) .parse(json) .read($.store.book[*], typeRef);3.3 谓词的三种创建方式JsonPath支持多种谓词创建方式适应不同复杂度的查询需求// 1. 内联谓词简单条件 ListMapString, Object inlineResults JsonPath.parse(json) .read($.store.book[?(.isbn ! null .price 15)]); // 2. Filter API中等复杂度 Filter filter Filter.filter( Criteria.where(price).lt(10) .and(category).is(fiction) ); ListMapString, Object filterResults JsonPath.parse(json) .read($.store.book[?], filter); // 3. 自定义谓词高度灵活 Predicate customPredicate new Predicate() { Override public boolean apply(PredicateContext ctx) { MapString, Object book ctx.item(Map.class); return book.containsKey(isbn) ((Number)book.get(price)).doubleValue() 10; } }; ListMapString, Object customResults JsonPath.parse(json) .read($.store.book[?], customPredicate);4. 高级特性与实战技巧4.1 配置选项详解JsonPath提供了多种配置选项来调整其行为// 常用配置组合 Configuration config Configuration.builder() .options(Option.DEFAULT_PATH_LEAF_TO_NULL, Option.SUPPRESS_EXCEPTIONS) .mappingProvider(new JacksonMappingProvider()) .build(); // 返回路径而非值 Configuration pathConfig Configuration.builder() .options(Option.AS_PATH_LIST) .build(); ListString paths JsonPath.using(pathConfig) .parse(json) .read($..author);4.2 JSON修改操作JsonPath不仅支持查询还能修改JSON文档// 修改值 String updatedJson JsonPath.parse(json) .set($.store.book[0].price, 9.99) .jsonString(); // 添加新字段 updatedJson JsonPath.parse(updatedJson) .put($.store.book[0], inStock, true) .jsonString(); // 删除字段 updatedJson JsonPath.parse(updatedJson) .delete($.store.book[0].inStock) .jsonString();4.3 性能调优建议缓存配置对于频繁使用的路径启用缓存可以显著提升性能提供者选择根据你的JSON库偏好选择合适的JsonProvider批量操作尽量减少单独查询合并为一次路径表达式懒解析对于大型文档考虑使用流式解析与JsonPath的组合// 自定义缓存实现示例 CacheProvider.setCache(new Cache() { private final MapString, JsonPath cache new ConcurrentHashMap(100); Override public JsonPath get(String key) { return cache.get(key); } Override public void put(String key, JsonPath jsonPath) { cache.put(key, jsonPath); } });在实际项目中JsonPath特别适合以下场景API网关的响应转换日志分析中的字段提取配置文件的多环境适配测试断言中的JSON验证我曾在一个电商平台项目中使用JsonPath将原本需要数百行代码的订单数据分析逻辑缩减为不到50行而且可读性大幅提升。特别是在处理第三方支付回调时JsonPath的灵活查询让我们能够快速适配不同支付提供商的响应格式变化。

相关文章:

别再手动解析JSON了!用Jayway JsonPath 2.7.0 + Java,5分钟搞定复杂数据提取

告别JSON解析噩梦:Jayway JsonPath在Java中的高效实践 JSON作为现代数据交换的事实标准,几乎渗透到了每一个Java开发者的日常工作中。无论是微服务间的通信、第三方API的响应,还是日志分析中的数据提取,我们总在与各种复杂嵌套的J…...

Element Plus后台管理系统实战:给任务调度模块加个my-cron-vue3配置器(附完整代码)

Element Plus后台管理系统实战:给任务调度模块加个my-cron-vue3配置器(附完整代码) 在后台管理系统的开发中,任务调度功能几乎是标配。想象一下这样的场景:运营团队需要在每天凌晨2点自动生成报表,每周一早…...

如何实现40+平台直播自动录制?DouyinLiveRecorder完整指南

如何实现40平台直播自动录制?DouyinLiveRecorder完整指南 【免费下载链接】DouyinLiveRecorder 可循环值守和多人录制的直播录制软件,支持抖音、TikTok、Youtube、快手、虎牙、斗鱼、B站、小红书、pandatv、sooplive、flextv、popkontv、twitcasting、wi…...

如何用AI一键分离图像图层?5步掌握专业设计自动化

如何用AI一键分离图像图层?5步掌握专业设计自动化 【免费下载链接】layerdivider A tool to divide a single illustration into a layered structure. 项目地址: https://gitcode.com/gh_mirrors/la/layerdivider 在数字设计领域,layerdivider作…...

告别Sprite!用OffscreenCanvas在Mapbox GL JS中动态生成多色图标(附完整代码)

告别Sprite!用OffscreenCanvas在Mapbox GL JS中动态生成多色图标(附完整代码) 在WebGIS开发中,图标管理一直是让开发者头疼的问题。传统Sprite方案虽然能一次性加载所有图标,但当我们需要根据数据动态改变图标颜色时&a…...

对比直接采购,通过聚合平台使用大模型API的月度账单清晰度感受

对比直接采购,通过聚合平台使用大模型API的月度账单清晰度感受 1. 多厂商账单的混杂痛点 作为个人开发者,我曾同时使用多个厂商的大模型API进行项目开发。每个厂商的计费方式、账单周期和用量统计格式各不相同,有的按Token计费,…...

告别理论推导:用Python+NumPy手把手模拟MSK信号生成与频谱分析

用Python实战解析MSK调制:从信号生成到频谱特性对比 在数字通信系统中,调制技术的选择直接影响着频谱效率和功率利用率。最小频移键控(MSK)作为一种特殊的连续相位频移键控(CP-FSK),因其恒包络特性和高频谱效率,在卫星通信、无线传…...

基于AI与RSS的智能信息筛选:构建个人技术摘要系统

1. 项目概述与核心价值如果你和我一样,每天被海量的技术资讯淹没,想从上百个优质博客里筛选出真正值得一读的内容,但又苦于时间有限,那么这个项目可能就是你的“数字信息管家”。ai-daily-digest是一个为 OpenClaw AI 智能体平台设…...

终极指南:如何为欧洲卡车模拟2打造智能自动驾驶体验

终极指南:如何为欧洲卡车模拟2打造智能自动驾驶体验 【免费下载链接】Euro-Truck-Simulator-2-Lane-Assist Plugin based interface program for ETS2/ATS. 项目地址: https://gitcode.com/gh_mirrors/eur/Euro-Truck-Simulator-2-Lane-Assist 想象一下&…...

告别表格!用PyTorch实战策略梯度(Policy Gradient),5步搞定REINFORCE算法

告别表格!用PyTorch实战策略梯度(Policy Gradient),5步搞定REINFORCE算法 在强化学习领域,策略梯度(Policy Gradient)方法正逐渐成为解决复杂决策问题的主流选择。与传统的表格型方法相比&#…...

从Wi-Fi到5G:深入浅出聊聊BER(误比特率)在实际通信系统里到底有多重要?

从Wi-Fi到5G:误比特率如何塑造你的数字生活体验 1. 当视频卡顿时,BER在幕后做了什么? 深夜追剧时突然出现的马赛克画面,或是视频会议中同事凝固的表情——这些让人抓狂的瞬间,往往与一个名为误比特率(BER&a…...

没有GPU也能玩转PINN?手把手教你用CPU在云服务器上跑通Burgers方程仿真

没有GPU也能玩转PINN?手把手教你用CPU在云服务器上跑通Burgers方程仿真 物理信息神经网络(PINN)作为AI与科学计算交叉领域的前沿技术,正吸引着越来越多研究者的目光。但许多初学者常被一个误区困扰:必须配备高端GPU才能…...

3分钟搞定音乐解锁:Unlock-Music让你的加密音频重获自由

3分钟搞定音乐解锁:Unlock-Music让你的加密音频重获自由 【免费下载链接】unlock-music 在浏览器中解锁加密的音乐文件。原仓库: 1. https://github.com/unlock-music/unlock-music ;2. https://git.unlock-music.dev/um/web 项目地址: htt…...

微信单向好友检测技术难题与自动化解决方案

微信单向好友检测技术难题与自动化解决方案 【免费下载链接】WechatRealFriends 微信好友关系一键检测,基于微信ipad协议,看看有没有朋友偷偷删掉或者拉黑你 项目地址: https://gitcode.com/gh_mirrors/we/WechatRealFriends 在数字化社交时代&am…...

终极指南:OpenCore Legacy Patcher让老Mac重获新生的完整教程

终极指南:OpenCore Legacy Patcher让老Mac重获新生的完整教程 【免费下载链接】OpenCore-Legacy-Patcher Experience macOS just like before 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 想让2015款MacBook Pro运行最新的ma…...

别再只会用GPIO读按键了!用STM32的ADC实现矩阵按键,节省IO口的硬件设计思路

突破传统:用STM32的ADC实现高性价比矩阵按键设计 在嵌入式系统开发中,按键输入是最基础却又最常遇到的功能需求之一。传统GPIO按键方案虽然简单直接,但在IO资源紧张的多功能设备中,往往成为制约设计灵活性的瓶颈。想象一下&#x…...

PyGPT:本地化AI助手部署与多模态应用实战指南

1. 项目概述:PyGPT,一个全能的桌面AI助手如果你和我一样,对ChatGPT这类在线AI助手的强大能力感到兴奋,但又时常受限于其网络环境、隐私顾虑,或者希望它能更深度地融入你的本地工作流,那么PyGPT的出现&#…...

终极暗黑2存档编辑器:5分钟打造你的个性化游戏体验

终极暗黑2存档编辑器:5分钟打造你的个性化游戏体验 【免费下载链接】d2s-editor 项目地址: https://gitcode.com/gh_mirrors/d2/d2s-editor 你知道吗?还在为暗黑破坏神2中重复刷装备而烦恼?想快速体验不同职业build却不想从头练级&am…...

用ESPHome和Home Assistant玩转WS2812B灯带:从氛围灯到节日装饰的保姆级配置

用ESPHome和Home Assistant玩转WS2812B灯带:从氛围灯到节日装饰的保姆级配置 在智能家居的海洋中,灯光控制是最能体现"智能"二字的领域之一。而WS2812B可编程RGB灯带,就像一位全能的灯光魔术师,仅用一根数据线就能控制数…...

INAV PID控制器终极调参指南:7个简单技巧让无人机飞行稳如磐石

INAV PID控制器终极调参指南:7个简单技巧让无人机飞行稳如磐石 【免费下载链接】inav INAV: Navigation-enabled flight control software 项目地址: https://gitcode.com/gh_mirrors/in/inav INAV(导航增强飞行控制软件)是一款功能强…...

拒绝职场停滞:海归程序员突破 SDE II 瓶颈的进阶指南

很多留学生凭借扎实的代码基本功和高强度的加班,能在入职前两三年内迅速从初级(Junior)跃升至中级工程师(SDE II)。然而,当职业生涯迈入第五个年头,绝大多数人会撞上一面极其坚硬的“隐形高墙”…...

审稿人视角:你的IEEE论文在Related Work里踩了哪些雷?

IEEE论文Related Work章节的审稿人避雷指南 Related Work章节常被视为论文中最"套路化"的部分,却恰恰是审稿人判断研究者学术素养的第一道关卡。资深IEEE审稿人往往通过这一章节就能预判论文的学术价值——那些堆砌文献却缺乏批判性思考的"文献目录式…...

使用 Node.js 在 Ubuntu 后端服务中集成 Taotoken 多模型能力

使用 Node.js 在 Ubuntu 后端服务中集成 Taotoken 多模型能力 1. 环境准备与依赖安装 在 Ubuntu 系统中运行 Node.js 后端服务需要确保已安装 Node.js 运行环境。推荐使用 LTS 版本以获得长期支持。可以通过以下命令检查 Node.js 和 npm 是否已安装: node -v npm…...

为什么92%的PHP项目还在手写表单逻辑?揭秘被低估的PSR-14事件驱动表单引擎架构

更多请点击: https://intelliparadigm.com 第一章:PHP表单开发的现状与认知陷阱 当前,大量遗留 PHP 应用仍依赖 $_POST 和 $_GET 直接读取表单数据,缺乏输入验证、CSRF 防护与输出转义机制,导致 XSS、SQL 注入与会话…...

九大网盘直链下载解决方案:打破速度壁垒的技术实践

九大网盘直链下载解决方案:打破速度壁垒的技术实践 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘 / 天翼云盘…...

RTranslator大模型下载问题解决指南:从卡顿到流畅的完整实用方案

RTranslator大模型下载问题解决指南:从卡顿到流畅的完整实用方案 【免费下载链接】RTranslator Open source real-time translation app for Android that runs locally 项目地址: https://gitcode.com/GitHub_Trending/rt/RTranslator RTranslator是一款开源…...

终极指南:5步实现Deceive游戏状态伪装,英雄联盟离线模式全解析

终极指南:5步实现Deceive游戏状态伪装,英雄联盟离线模式全解析 【免费下载链接】Deceive 🎩 Appear offline for League of Legends, VALORANT, and Legends of Runeterra. 项目地址: https://gitcode.com/gh_mirrors/de/Deceive 你是…...

从一次线上Referrer泄露事故说起:聊聊strict-origin-when-cross-origin的实战价值

从一次线上Referrer泄露事故说起:聊聊strict-origin-when-cross-origin的实战价值 去年夏天,我们团队经历了一次令人警醒的安全事件。当时公司新上线了一个数据分析平台,运营团队在后台配置了几个第三方统计工具的埋点代码。两周后的某个深夜…...

使用 pip install 命令快速安装并配置 Taotoken Python SDK 的完整指南

使用 pip install 命令快速安装并配置 Taotoken Python SDK 的完整指南 1. 环境准备与 SDK 安装 确保您的 Python 环境版本在 3.7 或以上。推荐使用虚拟环境管理依赖: python -m venv taotoken-env source taotoken-env/bin/activate # Linux/macOS # 或 taotok…...

茉莉花插件:5分钟掌握Zotero中文文献管理的终极解决方案

茉莉花插件:5分钟掌握Zotero中文文献管理的终极解决方案 【免费下载链接】jasminum A Zotero add-on to retrive CNKI meta data. 一个简单的Zotero 插件,用于识别中文元数据 项目地址: https://gitcode.com/gh_mirrors/ja/jasminum 还在为管理海…...