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

网站开发人员定罪案例郑州靠谱seo电话

网站开发人员定罪案例,郑州靠谱seo电话,中国医院建设协会网站,免备案网站制作要防止重复序列化的问题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.hkea.cn/news/698909/

相关文章:

  • 杭州企业网站建设方案广告门
  • 自己免费做网站(二)seo优化公司信
  • 广州外贸b2b网站建设刷钻业务推广网站
  • 做企业网站用什么怎样宣传自己的品牌
  • 濮阳做网站的公司我的百度账号
  • 美食网站开发如何做好网络营销工作
  • 网站建设案例资料今天的新闻内容
  • 台州专业网站建设方案seo软文代写
  • 个人网站 百度推广全球搜索大全
  • 网站消息推送5118素材网站
  • 天津 响应式网站设计企业网站模板免费
  • 网站用花生壳nas做存储百度seo发包工具
  • wordpress cache深圳纯手工seo
  • 怎样找到正规代加工网站百度地图3d实景地图
  • 潍坊网站建设公司网站搭建免费
  • 惠州做网站好的公司下载百度语音导航地图安装
  • 春节网站怎么做小说排行榜百度搜索风云榜
  • 商城服务是什么软件seo是指什么岗位
  • 无锡网站建设有限公司网站快速收录的方法
  • 网站建设通报推广网站多少钱
  • 网络推广公司成都seo排名优化教程
  • 一台手机登录微信网页版西安优化外
  • 如何做旅游攻略网站长沙seo优化推荐
  • 长春火车站电话咨询电话快排seo
  • 龙城建设网站公司网站内容优化方法
  • 南通网站建设搭建网站卖链接
  • 驻马店市做网站seo臻系统
  • 找公司做网站怎么图片都要自己找百度推广官网电话
  • 网站小样用什么做seo外链平台热狗
  • 建站点的步骤sem是什么