com.alibaba.fastjson.JSONException: not close json text, token : error

今天遇到一个相当智障的问题,前端传参数到后端,后端直接报json解析错误,not close?? 听着就很奇怪,关键有的时候正常,有的时候不正常。于是先在浏览器中F12,看传的参数 感觉 没问题,在后端filter中获得request的body,打印出来,很长,也看不出来问题。

1、先来看一下用以接收参数的dto

bash 复制代码
@Data
public class DeliveryFeeProcessDTO extends TDeliveryFeeProcessRecord {

    /**
     * 货物明细
     */
    private List<TDeliveryFeeProcessGoodsInfo> goodsList;

    /**
     * 文件列表
     */
    private List<FileInfo> fileList;

    /**
     * 1 通过
     * 0 驳回
     */
    private Integer state;
}

项目中配置的是fastjson,1.2.83

bash 复制代码
  http:
    converters:
      preferred-json-mapper: fastjson       # Json转换器


        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.83</version>
        </dependency>

可以看到有两个list 比较可疑··

2、看一下我精简后的json 字符串,这也能报错?

bash 复制代码
{"creatorId": "superadmin","goodsList": "","fileList": ""}

3、写一个demo

bash 复制代码
public static void main(String[] args) {
//        String json = "{\"creatorId\": \"superadmin\",\"goodsList\": \"\",\"fileList\": []}";
        dealJson("{\"creatorId\": \"superadmin\",\"goodsList\": \"\"}");
        dealJson("{\"creatorId\": \"superadmin\",\"fileList\": \"\"}");
        dealJson("{\"creatorId\": \"superadmin\",\"goodsList\": []}");
        dealJson("{\"creatorId\": \"superadmin\",\"fileList\": []}");
        dealJson("{\"creatorId\": \"superadmin\",\"goodsList\": \"\",\"fileList\": []}");
        dealJson("{\"creatorId\": \"superadmin\",\"goodsList\": \"\",\"fileList\": \"\"}");
        dealJson("{\"creatorId\": \"superadmin\",\"goodsList\": [],\"fileList\": []}");
        dealJson("{\"creatorId\": \"superadmin\",\"goodsList\": [],\"fileList\": \"\"}");
    }

    private static void dealJson(String json) {
        Boolean flag = true;
        try {
            DeliveryFeeProcessDTO dto = JSONObject.parseObject(json, DeliveryFeeProcessDTO.class);
        }catch (Exception e){
            flag = false;
//            System.out.println(json);
            System.out.println(e.getMessage());
//            e.printStackTrace();
        }
        if(flag){
            System.out.println("PASS"+json);
        }else {
            System.out.println("FAILED"+json);
        }
    }

出来的结果是

bash 复制代码
FAILED{"creatorId": "superadmin","goodsList": ""}
FAILED{"creatorId": "superadmin","fileList": ""}
PASS{"creatorId": "superadmin","goodsList": []}
PASS{"creatorId": "superadmin","fileList": []}
FAILED{"creatorId": "superadmin","goodsList": "","fileList": []}
FAILED{"creatorId": "superadmin","goodsList": "","fileList": ""}
PASS{"creatorId": "superadmin","goodsList": [],"fileList": []}
PASS{"creatorId": "superadmin","goodsList": [],"fileList": ""}

可以看到,应该是因为List不能是空字符串,必须是空数组才行

但是最后一个就很鬼畜了!!竟然PASS了!

好了,省流(我懒得去翻fastjson的源码,更懒得去看fastjson的release note)。解决办法是升级····简单粗暴。在maven仓库中查到最新是2.0.53

bash 复制代码
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>2.0.53</version>
        </dependency>

所以,每当你以为自己技术还行的时候,就会在小坑里栽跟头

相关推荐
aerror18 小时前
json转excel xlsx文件
开发语言·python·json
掉鱼的猫1 天前
全球首个支持 IETF JSONPath (RFC 9535) 标准的 Java 框架,Snack4-Jsonpath v4.0.0 发布
java·json
吹个口哨写代码2 天前
处理文本编辑器存的json格式报错问题,对编辑器存的字段进行转换处理,再通过json返回
java·编辑器·json
APIshop2 天前
代码实例:Python 爬虫抓取与解析 JSON 数据
爬虫·python·json
得物技术2 天前
从 JSON 字符串到 Java 对象:Fastjson 1.2.83 全程解析|得物技术
java·后端·json
GISBox3 天前
GISBox如何让GeoTIFF突破Imagery Provider加载限制?
react.js·json·gis
C嘎嘎嵌入式开发3 天前
(20)100天python从入门到拿捏《JSON 数据解析》
开发语言·python·json
LazerYvTian3 天前
Json数据字段类型兼容性处理
json
weixin_307779134 天前
使用Python高效读取ZIP压缩文件中的UTF-8 JSON数据到Pandas和PySpark DataFrame
开发语言·python·算法·自动化·json
霜绛4 天前
Unity:Json笔记——Json文件格式、JsonUtlity序列化和反序列化
学习·unity·json·游戏引擎