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

安徽省住房建设厅网站制作一个网页的步骤

安徽省住房建设厅网站,制作一个网页的步骤,网站开发形式选择,专业 旅游网站建设要防止重复序列化的问题JSON.toJSONString(entity) 20241213 10:29 背景: 我在设计业务实现echart图标渲染,业务接口实时性查询耗时很长,为了提高系统可用性和用户体验,采用中间表的方案——即在中间表中存储大JSON。 但是在自测…

要防止重复序列化的问题JSON.toJSONString(entity)

20241213 10:29

背景:

我在设计业务实现echart图标渲染,业务接口实时性查询耗时很长,为了提高系统可用性和用户体验,采用中间表的方案——即在中间表中存储大JSON。
但是在自测环节发现数据库中的json串格式有被多次序列化JSON.toJSONString(entity) 。疑惑了 所以就去看了下同事相关的业务接口 ,不得了 同事写的接口有的加了JSON.toJSONString序列化, 有的没加,简直就是坑啊。我怎么确定他有没有序列化啊,总不至于每个都判断一次吧…不管了,直接兜底处理吧,又称shi上堆shi。

他这种写法 直接导致,我在获取解析json的时候会有格式报错,因为无法确定到底被序列化了几次!

具体解决方案如下:

Q、

我要存储json字符串到mysql text字段中。代码使用JSON.toJSONString(entity) ,可能entity本身就是json字符串格式,为了防止两次toJSONString的情况 怎么处理。

在这里插入图片描述

A、

在存储 JSON 字符串到 MySQL 的 TEXT 字段时,确实需要防止重复序列化的问题。如果 entity 本身已经是 JSON 字符串,再次使用 JSON.toJSONString() 会导致转义符等问题。

解决方案

在调用 JSON.toJSONString() 之前,可以先检查 entity 是否已经是一个合法的 JSON 字符串。以下是两种常见方法:


方法 1:使用 JSONValidator 验证

JSONValidator 是 FastJSON 提供的工具,用于验证字符串是否是合法的 JSON 格式。

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.alibaba.fastjson.JSONValidator;public class JsonStorageExample {public static String ensureJsonString(Object entity) {if (entity instanceof String) {String jsonString = (String) entity;// 验证是否是合法的 JSON 字符串if (JSONValidator.from(jsonString).validate()) {return jsonString; // 已是 JSON 字符串,无需再次序列化}}// 对非字符串类型或非合法 JSON 字符串的对象进行序列化return JSON.toJSONString(entity);}public static void main(String[] args) {// 示例Object entity1 = "{\"key\":\"value\"}"; // 已经是 JSON 字符串Object entity2 = new JSONObject(); // 非 JSON 字符串((JSONObject) entity2).put("key", "value");System.out.println(ensureJsonString(entity1)); // 输出:{"key":"value"}System.out.println(ensureJsonString(entity2)); // 输出:{"key":"value"}}
}

方法 2:手动判断是否是 JSON 格式

如果不想引入 JSONValidator,可以通过捕获异常的方式简单判断:

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;public class JsonStorageExample {public static String ensureJsonString(Object entity) {if (entity instanceof String) {String jsonString = (String) entity;try {// 尝试解析字符串为 JSON 对象JSON.parse(jsonString);return jsonString; // 如果解析成功,说明是合法 JSON} catch (Exception e) {// 如果解析失败,说明不是合法 JSON,继续序列化}}// 对非字符串类型或非合法 JSON 字符串的对象进行序列化return JSON.toJSONString(entity);}public static void main(String[] args) {Object entity1 = "{\"key\":\"value\"}"; // 已经是 JSON 字符串Object entity2 = new JSONObject(); // 非 JSON 字符串((JSONObject) entity2).put("key", "value");System.out.println(ensureJsonString(entity1)); // 输出:{"key":"value"}System.out.println(ensureJsonString(entity2)); // 输出:{"key":"value"}}
}

优化点

  1. 尽量避免重复序列化:
    • 优先判断是否是 JSON 字符串,减少不必要的序列化操作。
  2. 使用更高效的存储方式:
    • 如果可能,考虑使用 MySQL 的 JSON 类型字段(需要 MySQL 5.7 或更高版本)。这样可以直接存储 JSON 对象并支持 JSON 查询功能。
  3. 日志记录:
    • 如果 entity 格式异常或解析失败,可以记录日志以方便排查问题。

希望对你有所帮助! 关注我为程序员职业生涯蓄能破局。

http://www.yayakq.cn/news/53535/

相关文章:

  • 个人网站空间价格海南网上申请营业执照步骤
  • 电商网站建设方案100例厦门网络推广建网站
  • 织梦小说网站模板saas建站 cms
  • 企业网站建设之后wordpress菜单默认对游客不显示
  • 织梦网站图片代码调用别人网站的数据库
  • 大渡口网站建设商城网站设计制作
  • 连云港做电商网站的公司承德网站建设作用
  • 重庆有哪些做网站公司好深圳个人网站建设
  • 定制网站大概多少钱阳江房产网0662
  • 凡科网站官网网站建设中的安全问题
  • 现在什么省网站备案最快青岛网站建设公司效果
  • 四川省红鱼洞水库建设管理网站文山做网站yunling88
  • 南宁网站建设优化一个企业网站需要多少钱
  • 奢侈品的网站设计wordpress数据库查询优化
  • 怎么免费创建网站肇庆做网约车
  • 网站建设报价浩森宇特建筑公司企业愿景范文
  • 淄博做网站建设机械加工类网站
  • 怎么在网站后台删除图片建立自己的网站步骤
  • 网站服务器ip做视频链接网站
  • 网站做视频一个月有多少钱收入网站建设汇报
  • 如何自己学做网站网站建设忘记密码邮箱设置
  • 广州市住房和城乡建设局官方网站聚美优品网站建设分析
  • 网站建设中数据安全研究凡科建站下载
  • 做网站的公司属于什么行业wordpress做企业主页
  • 云南省建设厅网站查询网站前台做哪些工作
  • 凡科网可以免费做网站吗大数据精准获客平台
  • 杭州知名建设网站设计郑州开发小程序多少钱
  • H5酒店静态网站建设开题报告范文系统开发报价清单
  • 深圳做网站龙华信科西宁网站建设
  • 电动车网站模板组织建设求是网