fastJson toJsonString中的NPE问题

今天上线后看日志突然发现error暴增,赶紧看报错的内容,发现是一个NullPointException,再看定位到的代码行数,发现是一行日志,内容就是通过fastJson的toJsonString把入参实体转换为json字符串后打印出来,最后定位到的代码是这样一个方法

  public Integer getLogicAvailableReleaseQty(){
        return this.getLogicOccupyQty() - this.getLogicReleaseQty();
  }

这样一来问题就很明显了,入参的实体类并不是把表记录完整取出,导致了当前字段为null,自然报了npe
但是为什么fastjson的toJsonString会调用到这个方法,我在网上找到如下一段话:

会默认识别get开头的方法并且get后是大写字母的属性,并返回json
看了看源码,也确实发现fastjson有获取getter方法的行为,这算是一个隐藏的坑,以后确实需要小心。

ASMSerializerFactory.class:

  Context context = new Context(getters, beanInfo, classNameType, false,
                                          DisableCircularReferenceDetect);
posted @ 2022-01-18 18:07  CodeSpike  阅读(174)  评论(0编辑  收藏  举报
Live2D