0

0

如何在 Java 中正确解析多段连续的 JSON 响应流

花韻仙語

花韻仙語

发布时间:2026-01-17 21:41:12

|

826人浏览过

|

来源于php中文网

原创

如何在 Java 中正确解析多段连续的 JSON 响应流

本文介绍如何处理服务器逐段推送的多个独立 json 对象(如下载进度更新),解决“json 标准仅允许一个顶层值”导致的解析失败问题,并提供文件存储、流式读取与替代方案的专业实践。

在构建 Java REST 客户端时,若服务端以非数组形式、逐块推送多个独立 JSON 对象(即所谓的 JSON LinesNDJSON 格式),直接使用标准 JSON 解析器(如 Jackson 的 ObjectMapper.readValue() 或 Gson 的 fromJson())会抛出 com.fasterxml.jackson.core.JsonParseException: JSON standard allows only one top level value 错误——因为严格遵循 RFC 8259 的 JSON 规范要求整个文档必须且仅能有一个根值(对象或数组),而连续的 {...}{...}{...} 不符合语法。

✅ 正确做法:采用流式解析(Streaming Parsing)

推荐使用支持 JSON Lines(NDJSON) 的解析方式,即逐行读取、逐个解析独立 JSON 对象。Jackson 提供了开箱即用的支持:

Mistral AI
Mistral AI

Mistral AI被称为“欧洲版的OpenAI”,也是目前欧洲最强的 LLM 大模型平台

下载
import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper;

import java.io.File;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;

public class ContinuousJsonProcessor {
    private static final ObjectMapper mapper = new ObjectMapper();

    public static void processContinuousJsonFile(String filePath) throws IOException {
        JsonFactory factory = mapper.getFactory();
        try (JsonParser parser = factory.createParser(Files.newInputStream(Paths.get(filePath)))) {
            // 启用 JSON Lines 模式(允许重复 root)
            parser.configure(JsonParser.Feature.ALLOW_UNQUOTED_FIELD_NAMES, true); // 兼容无引号键(如 result)
            parser.configure(JsonParser.Feature.ALLOW_SINGLE_QUOTES, true);       // 兼容单引号字符串

            while (parser.nextToken() != null) {
                // 每次遇到 { 开始,解析一个完整对象
                JsonNode node = mapper.readTree(parser);
                System.out.println("→ 进度:" + 
                    node.path("result").path("percentage").asText() + " | " +
                    node.path("result").path("result").asText());
            }
        }
    }

    public static void main(String[] args) throws IOException {
        processContinuousJsonFile("continuous-response.json");
    }
}
⚠️ 注意:原始示例中字段名(如 result、percentage)未加双引号,属于非标准 JSON。上述代码通过启用 ALLOW_UNQUOTED_FIELD_NAMES 和 ALLOW_SINGLE_QUOTES 实现兼容;生产环境强烈建议服务端返回标准 JSON(所有键和字符串均用双引号包裹)。

? 替代方案对比与选型建议

方案 适用场景 优点 缺点
JSON Lines(逐行解析) 实时日志、进度流、服务端 SSE/HTTP streaming 响应 内存友好、低延迟、无需预加载全量数据 需手动处理解析边界,不支持随机访问
封装为 JSON 数组
[ {...}, {...}, {...} ]
批量离线测试、小规模响应集合 兼容所有标准 JSON 库,结构清晰 文件需重写追加,高频写入性能差;大文件易 OOM
单文件 → 多文件(如 progress_001.json, progress_002.json) 高并发写入、需并行处理 无锁、可分布式、易于清理 文件系统 I/O 开销增大,管理成本上升
轻量级嵌入式数据库(如 SQLite / H2) 需查询、过滤、分页、持久化保障 ACID 支持、索引加速、事务安全 引入额外依赖,增加部署复杂度

✅ 最佳实践总结

  • 优先采用 JSON Lines 流式解析:适用于真实服务端持续推送场景(如 HTTP chunked encoding 或 Server-Sent Events),避免内存膨胀;
  • 服务端应输出标准 JSON:确保字段名与字符串均使用双引号,提升跨语言兼容性;
  • 避免动态拼接大 JSON 数组文件:尤其在高频率更新时,频繁重写大文件将严重拖慢 I/O 性能;
  • 超大规模或强一致性需求 → 切换至数据库:例如将每条进度记录作为一行插入 SQLite 表,字段包括 id, timestamp, percentage, status;
  • 单元测试中模拟连续响应:可借助 OkHttp MockWebServer 或 WireMock 模拟分块响应头(Transfer-Encoding: chunked),验证客户端流式处理逻辑。

通过合理选择解析策略与存储模型,你不仅能优雅应对电影下载等长周期任务的进度反馈,还能为未来扩展实时监控、可观测性埋点打下坚实基础。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

835

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

740

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

736

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

399

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.6万人学习

C# 教程
C# 教程

共94课时 | 6.9万人学习

Java 教程
Java 教程

共578课时 | 47万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号