关于fastjson在Object转String时的一个坑

关于fastjson在Object转String时的一个坑关于fastjson在Object转String时的一个坑背景在公司的业务中有这么一个场景:需要将某个系统的结果对象放进Hbase中,然后被后续系统读取使用,在Hbase存储的时候,需要将对象中每个属性解析成字符串存入,但一开始存入接口的设计者只考虑了普通类型(Integer、Long、String之类)的字段存储,未考虑Map或者POJO对象的存储,因此原始代码如下: … if(O…

大家好,又见面了,我是你们的朋友全栈君。

关于fastjson在Object转String时的一个坑

背景

在公司的业务中有这么一个场景:需要将某个系统的结果对象放进Hbase中,然后被后续系统读取使用,在Hbase存储的时候,需要将对象中每个属性解析成字符串存入,但一开始存入接口的设计者只考虑了普通类型(Integer、Long、String之类)的字段存储,未考虑Map或者POJO对象的存储,因此原始代码如下:

	...
	if (Objects.nonNull(propertyValue)) { 
   
	     String value = propertyValue.toString();
	     put.add(Bytes.toBytes(family), Bytes.toBytes(properName), Bytes.toBytes(value));
	 }
	 ...

此处直接对对象中各字段的值判空后直接toString进行转换成String类型,当遇到Map或者POJO类时toString返回值是无法进行反序列化的。

以Map为例:
Map<String, Object> map = new HashMap<>(6);
map.put(“abc”, 123);
map.put(“qwe”, “QQQ”);
System.out.println(map.toString());
=================>
输出结果:
{abc=123, qwe=QQQ}
可以看出,根据这个输出结果是无法进行反序列化成Map对象的,POJO类如果不重写toString方法也是同样的道理。

坑记录

由于需求需要,要在Hbase中存储Map对象,所以代码改动如下:

	...
	if (Objects.nonNull(propertyValue)) { 
   
	     String value = JSONObject.toJSONString(propertyValue);
	     put.add(Bytes.toBytes(family), Bytes.toBytes(properName), Bytes.toBytes(value));
	 }
	 ...

测试发现Map对象可以正常被反序列化,看似没问题。结果,第二天大数据团队发现了很多数据统计都为0,排查后发现HBase中有几个字段的存储很怪异,有的字段会出现值被前后多了个双引号,即:本应该是abc的值,在Hbase中以”abc”的形式存在,导致大数据那里统计的数据全部为0。

正确姿势

那么如果遇到这种根据Object转String的情况该怎么处理,很简单,直接贴代码:

		Object obj = "abcd";
        String errStr = JSONObject.toJSONString(obj);
        String str = JSONObject.toJSON(obj).toString();
        System.out.println(errStr);
        System.out.println(str);

=======>
结果很明显:

"abcd"
abcd

Process finished with exit code 0

希望对未遇到过该问题但会经常接触到序列化反序列化的同学有所警示和帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/135441.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Redis的分布式锁详解

    Redis的分布式锁详解

    2021年4月10日
    171
  • 常见的预测模型及算法「建议收藏」

    常见的预测模型及算法「建议收藏」如果得到一份数据集,任务是要预测出一系列的值,而在预测任务中,我们大多数都采用的是拟合的方法,这篇文字主要介绍三种预测方法时间序列分析,灰色预测模型,神经网络。时间序列分析时间序列也叫动态序列,数据是按时间和数值性成的序列。而时间序列分析有三种作用,大致可以描述为描述过去,分析规律,预测将来。接下来将会讲到三种模型(季节分解,指数平滑,ARIMA模型)。一般情况下时间序列的数值变化规律有四种…

    2022年6月23日
    34
  • 开启1521端口监听_Oracle数据库常用命令、Linux监听配置、Oracle linux下开放1521端口…

    开启1521端口监听_Oracle数据库常用命令、Linux监听配置、Oracle linux下开放1521端口…一、Linux下Oracle数据库常用命令Oracle用户下执行:$sqlplussystem/manager@file.sql执行sql脚本文件$sqlplussystem/manager登录sqlplus,使用system用户$sqlplus/nolog以不连接数据库的方式启动sqlplus,启动数据时会用到$lsnrctlstatus/stop/startOrac…

    2022年6月7日
    46
  • STM32移植LWIP

    STM32移植LWIP本文使用的是STM32F207VCT6平台,MII接口的RTL8201EL网络芯片,LWIP版本是1.4.1基础工程是:已经实现了10ms定时,led灯1s闪烁,还有串口打印欢迎查看本文所在的系列,STM32的LWIP应用,点击跳转本文使用的IDE是IAR7.2,考虑到很多很使用Keil,本文末尾也有keil版本的说明添加以太网驱动库添加进工程,增加新库的头文件路径将LWIP源码放入目录中我们把s…

    2022年7月20日
    15
  • keil5破解失败【经验分享】

    keil5破解失败【经验分享】有些小伙伴在输入license时会出现这种情况解决办法:使用管理员方式运行keil5

    2022年5月4日
    823
  • Eclipse断点调试

    Eclipse断点调试作为开发人员,掌握开发环境下的调试技巧十分有必要。去年就想把关于Eclipse断点调试总结下了,由于对时间的掌控程度仍需极大提高,结果拖到今年才写了此篇博文。关于java调试技术还有很多,如JavaDebugInterface等,依据具体项目的需要,还有很多值得去研究和学习的。该博文仅就Eclipse断点调试技巧做下总结,不足够的地方还请大牛们指点。1 Debug视图1.1线程堆栈

    2022年5月21日
    95

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号