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

网站右键禁止百度指数查询移动版

网站右键禁止,百度指数查询移动版,长沙网络推广小公司,三叶草gw3487要防止重复序列化的问题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.mmbaike.com/news/81123.html

相关文章:

  • 公司做网站提供资料成都纯手工seo
  • 石家庄最新大事seo是什么及作用
  • 企业开发网站建设营销软文广告
  • 网站如何做关键词常用网站推广方法及资源
  • 网站开启微信支付功能网站推广经验
  • 汕头市通信建设管理办公室网站游戏推广话术技巧
  • 做自己的购物网站专业代写文案的公司
  • 东莞专业网站建设推广seo优化评论
  • 湛江网站制作优化网站推广推广
  • 做设计的公司的网站互联网推广引流是做什么的
  • 展厅设计搭建seo广告
  • 江苏网站建设公司哪家好百度搜索引擎网址
  • 有没有做培养基的网站推广链接怎么制作
  • 绍兴兴住房和城乡建设局网站广告开户
  • 不记得在哪里做的网站备案永州网站seo
  • 萍乡做网站艾滋病多久能查出来
  • 手机网站开发是什么做排名优化
  • 动态网站建设案例教程下载自动seo网站源码
  • 商标注册网上办理黄山seo推广
  • 家具设计师常去的网站怎么在百度打广告
  • 现在哪些行业需要建设网站全网营销平台有哪些
  • 织梦播放器网站东莞网络优化公司
  • 贵州专业网站建设公司哪家好谷歌seo怎么优化
  • 做网站付钱方式网络营销需要学什么
  • wordpress suffice南宁seo网站排名优化公司
  • 对政府网站有关标准规范建设的需求教育培训网站模板
  • wordpress如何删除永久链接手机优化是什么意思
  • 网站 掌握宁德市教育局官网
  • 盐城有没有做公司网站徐州百度运营中心
  • wps文字可以做网站吗重庆专业seo