我很菜 以下内容仅个人见解。。。。(中文api可参考 https://www.w3cschool.cn/fastjson/fastjson-api.html)
1、有时候需要map的属性转换成实体类(不是map的话可以使用BeanUtils.copyProperties()拷贝属性)使用Fastjson可以实现map向实体的转换
Object obj = JSON.parseObject(JSON.toJSONString(Map),Object.class);
// 除了在实体对象使用注解格式化日期还可以使用toJSONStringWithDateFormat方法,对于map格式日期很好用
Object obj= JSON.parseObject(JSON.toJSONStringWithDateFormat(Object,"yyyy-MM-dd",SerializerFeature.WriteMapNullValue),Object.class);
2、对象格式化json除了在对象属性注解之外还可以使用SerializerFeature进行格式化
// 是否输出值为null的字段,不使用SerializerFeature参数时默认为false
String s = JSON.toJSONString(Map,SerializerFeature.WriteMapNullValue);
具体如下表
| 名称 | 含义 |
| 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 |
| 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); |
| DisableCheckSpecialChar |
一个对象的字符串属性中如果有特殊字符如双引号,将会在转成json时带有反斜杠转移符。 如果不需要转义,可以使用这个属性。默认为false |
| NotWriteRootClassName | 含义 |
| BeanToArray | 将对象转为array输出 |
| WriteNonStringKeyAsString | 含义 |
| NotWriteDefaultValue | 含义 |
| BrowserSecure | 含义 |
| IgnoreNonFieldGetter | 含义 |
| WriteEnumUsingName | 含义 |
浙公网安备 33010602011771号