news 2026/6/22 13:05:20

SpringBoot进阶教程(八十七)数据压缩

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SpringBoot进阶教程(八十七)数据压缩

拆分JSON字符串​

1.1按结构拆分​

数组拆分​​:若JSON包含大型数组,可将其拆分为多个小数组。

复制代码

// 示例:将大数组拆分为多个子数组

JSONArray bigArray = new JSONArray(jsonString);

int chunkSize = 100;

for (int i = 0; i < bigArray.length(); i += chunkSize) {

JSONArray chunk = new JSONArray();

for (int j = i; j < Math.min(i + chunkSize, bigArray.length()); j++) {

chunk.put(bigArray.get(j));

}

String chunkJson = chunk.toString();

// 处理或保存chunkJson

}

复制代码

​​对象拆分​​:若JSON是嵌套对象,可按层级拆分为子对象。

1.2按大小拆分(流式处理)​​

使用流式API(如Jackson的JsonParser)逐块读取JSON内容,避免一次性加载到内存:

JsonFactory factory = new JsonFactory();

try (JsonParser parser = factory.createParser(new File("large.json"))) {

while (parser.nextToken() != null) {

// 逐Token处理,如按特定条件拆分

}

}

回到顶部

v压缩JSON字符串​

2.1使用GZIP压缩​

复制代码

import java.util.zip.GZIPOutputStream;

import java.io.ByteArrayOutputStream;

public static byte[] compress(String data) throws IOException {

ByteArrayOutputStream bos = new ByteArrayOutputStream(data.length());

try (GZIPOutputStream gzip = new GZIPOutputStream(bos)) {

gzip.write(data.getBytes());

}

return bos.toByteArray();

}

// 压缩后的数据可用于传输或存储

byte[] compressed = compress(jsonString);

复制代码

2.2使用Deflater压缩​

复制代码

import java.util.zip.Deflater;

public static byte[] deflateCompress(String data) {

Deflater deflater = new Deflater();

deflater.setInput(data.getBytes());

deflater.finish();

byte[] buffer = new byte[1024];

ByteArrayOutputStream outputStream = new ByteArrayOutputStream();

while (!deflater.finished()) {

int count = deflater.deflate(buffer);

outputStream.write(buffer, 0, count);

}

deflater.end();

return outputStream.toByteArray();

}

复制代码

回到顶部

v优化JSON体积​​

3.1移除无用空格​

使用紧凑格式(无缩进、换行):

new JSONObject(jsonString).toString(); // 默认紧凑格式

3.2​​缩短键名​

将长字段名替换为短名称:

{"n":"Alice","a":30} // 原始键名可能为"name"、"age"

回到顶部

v流式处理大型JSON​​

使用流式API逐步解析,避免内存溢出:

复制代码

// Jackson流式API示例

JsonFactory factory = new JsonFactory();

try (JsonParser parser = factory.createParser(new File("large.json"))) {

JsonToken token;

while ((token = parser.nextToken()) != null) {

if (token == JsonToken.START_ARRAY) {

while (parser.nextToken() != JsonToken.END_ARRAY) {

// 逐条处理数组元素

JsonNode node = parser.readValueAsTree();

// 处理node...

}

}

}

}

复制代码

回到顶部

v分页处理​

其实也是拆分,将数据拆成若干份

回到顶部

v实践方案

复制代码

import com.fasterxml.jackson.databind.JsonNode;

import com.fasterxml.jackson.databind.ObjectMapper;

import java.io.ByteArrayInputStream;

import java.io.ByteArrayOutputStream;

import java.io.IOException;

import java.util.zip.GZIPInputStream;

import java.util.zip.GZIPOutputStream;

import org.apache.commons.codec.binary.Base64;

import java.nio.charset.StandardCharsets;

public class CompressHelper {

private static final ObjectMapper objectMapper = new ObjectMapper();

/**

* 方式1:去除JSON中的空格/换行等冗余字符(文本压缩)

* @param formattedJson 格式化的JSON字符串(含空格换行)

* @return 紧凑格式的JSON字符串

* @throws IOException JSON解析异常

*/

public static String compressJsonByRemovingSpaces(String formattedJson) throws IOException {

JsonNode jsonNode = objectMapper.readTree(formattedJson);

return objectMapper.writeValueAsString(jsonNode);

}

/**

* 方式2:使用GZIP算法对JSON字符串进行二进制压缩(适合网络传输)

* @param json 原始JSON字符串

* @return Base64编码的压缩后字符串(可直接传输)

* @throws IOException 压缩异常

*/

public static String compressJsonByGzip(String json) throws IOException {

try (ByteArrayOutputStream byteOut = new ByteArrayOutputStream();

GZIPOutputStream gzipOut = new GZIPOutputStream(byteOut)) {

gzipOut.write(json.getBytes("UTF-8"));

gzipOut.finish();

return Base64.encodeBase64String(byteOut.toByteArray());

}

}

public static String decompressJson(String source) throws IOException {

byte[] compressedData = Base64.decodeBase64(source);

try (ByteArrayInputStream byteIn = new ByteArrayInputStream(compressedData);

GZIPInputStream gzipIn = new GZIPInputStream(byteIn);

ByteArrayOutputStream byteOut = new ByteArrayOutputStream()) {

// 读取压缩数据并解压缩

byte[] buffer = new byte[1024];

int len;

while ((len = gzipIn.read(buffer)) != -1) {

byteOut.write(buffer, 0, len);

}

return byteOut.toString(StandardCharsets.UTF_8.name());

}

}

}

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/19 11:59:49

CVAT权限管理全攻略:从零构建安全高效的标注团队协作体系

CVAT权限管理全攻略&#xff1a;从零构建安全高效的标注团队协作体系 【免费下载链接】cvat Annotate better with CVAT, the industry-leading data engine for machine learning. Used and trusted by teams at any scale, for data of any scale. 项目地址: https://gitco…

作者头像 李华
网站建设 2026/6/21 21:40:06

Kubernetes Service详解:实现服务发现与负载均衡

. Service概念引入k8s之部署Deployment章节我们介绍RS以及Deployment&#xff0c;Deployment提供了pod的管理方式&#xff0c;以及通过副本控制器RC保证集群中pod的数量保持为指定数量。同时Deployment还提供了相关升级、回滚、更新速度、灰度发布等功能。那么pod之间怎么进行访…

作者头像 李华
网站建设 2026/6/16 7:17:49

k8s使用kubectl报错

k8s使用kubectl报错&#xff1a;[rootmaster01 ~]# kubectl get nodes The connection to the server localhost:8080 was refused - did you specify the right host or port?检查kubelet状态&#xff0c;发现没启动成功[rootnode02 ~]# kubectl status kubelet E1217 23:04:…

作者头像 李华
网站建设 2026/6/22 7:42:43

DuckDB Java集成实战:从零构建高性能数据分析应用

DuckDB Java集成实战&#xff1a;从零构建高性能数据分析应用 【免费下载链接】duckdb DuckDB is an in-process SQL OLAP Database Management System 项目地址: https://gitcode.com/GitHub_Trending/du/duckdb 传统关系型数据库在数据分析场景中常常面临性能瓶颈&…

作者头像 李华
网站建设 2026/6/22 16:38:08

Monaco Editor集成终极指南:从架构解析到生产级部署方案

Monaco Editor集成终极指南&#xff1a;从架构解析到生产级部署方案 【免费下载链接】monaco-editor A browser based code editor 项目地址: https://gitcode.com/gh_mirrors/mo/monaco-editor 你是否在集成Monaco Editor时遭遇过"语言服务不可用"、"Wo…

作者头像 李华
网站建设 2026/6/22 11:41:32

电动汽车仿真终极指南:AVL-CRUISE动力性经济性完整教程

电动汽车仿真终极指南&#xff1a;AVL-CRUISE动力性经济性完整教程 【免费下载链接】AVL-CRUISE纯电动汽车动力性经济性仿真资源介绍分享 本资源文件详细介绍了如何利用AVL-CRUISE软件进行纯电动汽车的动力性经济性仿真。通过该文件&#xff0c;您将学习到如何设置仿真模型、输…

作者头像 李华