首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >fastJson使用toJSONString()时自动过滤掉值为null

fastJson使用toJSONString()时自动过滤掉值为null

原创
作者头像
用户7166392
修改2020-06-02 10:31:15
修改2020-06-02 10:31:15
10.6K0
举报
文章被收录于专栏:KongKongKongKong

一、诱发原因

在做项目时候需要将json对象转化为String字符串,很自然的可以想到使用toJSONString方法,那么这里问题就来了,在使用该方法的时候发现了一个问题,当接收到的报文有null值时,在转化为json字符串时为null的字段会被自动过滤掉,查询资料字后发现可以使用一些序列化的参数来处理这种情况

二、处理

JSONObject.toJSONString(result,SerializerFeature.WriteMapNullValue);

使用这种方式给给方法添加序列化参数的方式可以做到将空值以null作为value保存,具体参数如下

QuoteFieldNames,//输出key时是否使用双引号,默认为true

UseSingleQuotes,//使用单引号而不是双引号,默认为false

WriteMapNullValue,//是否输出值为null的字段,默认为false

WriteEnumUsingToString,//Enum输出name()或者original,默认为false

UseISO8601DateFormat,//Date使用ISO8601格式输出,默认为false

WriteNullListAsEmpty,//List字段如果为null,输出为[],而非null

WriteNullStringAsEmpty,//字符类型字段如果为null,输出为"",而非null

WriteNullNumberAsZero,//数值字段如果为null,输出为0,而非null

WriteNullBooleanAsFalse,//Boolean字段如果为null,输出为false,而非null

SkipTransientField,//如果是true,类中的Get方法对应的Field是transient,序列化时将会被忽略。默认为true

SortField,//按字段名称排序后输出。默认为false

@Deprecated

WriteTabAsSpecial,//把\t做转义输出,默认为false

PrettyFormat,//结果是否格式化,默认为false

WriteClassName,//序列化时写入类型信息,默认为false。反序列化是需用到

DisableCircularReferenceDetect,//消除对同一对象循环引用的问题,默认为false

WriteSlashAsSpecial,//对斜杠'/'进行转义

BrowserCompatible,//将中文都会序列化为\uXXXX格式,字节数会多一些,但是能兼容IE 6,默认为false

WriteDateUseDateFormat,//全局修改日期格式,默认为false。JSON.DEFFAULT_DATE_FORMAT = "yyyy-MM-dd";JSON.toJSONString(obj, SerializerFeature.WriteDateUseDateFormat);

NotWriteRootClassName,//暂不知,求告知

DisableCheckSpecialChar,//一个对象的字符串属性中如果有特殊字符如双引号,将会在转成json时带有反斜杠转移

三、延伸

/**

* fastjson过滤器将null值转换为字符串

*/

public static final ValueFilter FILTER = new ValueFilter() {

@Override

public Object process(Object obj, String s, Object v) {

if(v==null)

return "";

return v;

}

};

 JSONObject.toJSONString(result,FILTER ,SerializerFeature.WriteMapNullValue);

这样就可以做到将值为null的value存为空字串。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档