news 2026/4/23 14:37:58

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/4/20 5:54:51

8款Blender必备插件:让3D创作效率翻倍的终极指南

作为一名Blender用户&#xff0c;你是否经常遇到这样的困扰&#xff1a;建模过程繁琐耗时&#xff0c;渲染效果不尽人意&#xff0c;动画制作复杂难懂&#xff1f;别担心&#xff0c;这正是Blender插件生态系统的价值所在&#xff01;通过精心挑选的插件&#xff0c;你可以将创…

作者头像 李华
网站建设 2026/4/23 12:31:42

Easy Effects终极指南:从新手到专业音频调校师

Easy Effects终极指南&#xff1a;从新手到专业音频调校师 【免费下载链接】easyeffects Limiter, compressor, convolver, equalizer and auto volume and many other plugins for PipeWire applications 项目地址: https://gitcode.com/gh_mirrors/ea/easyeffects 还在…

作者头像 李华
网站建设 2026/4/23 8:06:26

终极快速博客搭建指南:5分钟拥有现代化专业博客

终极快速博客搭建指南&#xff1a;5分钟拥有现代化专业博客 【免费下载链接】tailwind-nextjs-starter-blog This is a Next.js, Tailwind CSS blogging starter template. Comes out of the box configured with the latest technologies to make technical writing a breeze.…

作者头像 李华
网站建设 2026/4/22 22:56:06

语音识别准确率翻倍秘诀:FunASR采样率参数深度解析

语音识别准确率翻倍秘诀&#xff1a;FunASR采样率参数深度解析 【免费下载链接】FunASR A Fundamental End-to-End Speech Recognition Toolkit and Open Source SOTA Pretrained Models, Supporting Speech Recognition, Voice Activity Detection, Text Post-processing etc.…

作者头像 李华
网站建设 2026/4/21 9:50:02

Paddle-Lite Java API:Android端AI模型部署实战指南

Paddle-Lite Java API&#xff1a;Android端AI模型部署实战指南 【免费下载链接】Paddle-Lite PaddlePaddle High Performance Deep Learning Inference Engine for Mobile and Edge (飞桨高性能深度学习端侧推理引擎&#xff09; 项目地址: https://gitcode.com/GitHub_Tren…

作者头像 李华