关键词:
Fastjson
这玩意儿不多说,Alibaba出品,出过几次严重的安全漏洞,但是依然很流行。这里写一下它怎么处理枚举。
<!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.76</version>
</dependency>
序列化为name()值
默认就是,啥也不用动
import com.alibaba.fastjson.JSON;
enum Gender {
BOY, GIRL, UNKNOW
}
class User {
private Integer id;
private Gender gender;
public User() {
}
public User(Integer id, Gender gender) {
super();
this.id = id;
this.gender = gender;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Gender getGender() {
return gender;
}
public void setGender(Gender gender) {
this.gender = gender;
}
}
public class MainTest {
public static void main(String[] args) throws Exception {
// 序列化为JSON输出
User user = new User(1, Gender.BOY);
String jsonString = JSON.toJSONString(user);
System.out.println(jsonString); // {"gender":"BOY","id":1}
// 反序列化为对象
user = JSON.parseObject(jsonString, User.class);
System.out.println(user.getGender()); // BOY
}
}
序列化为ordinal()值
全局设置
代码跟上面没有变化,就需要在开头添加一句代码,任何枚举,都会被序列化为ordinal()值
JSON.DEFAULT_GENERATE_FEATURE &= ~SerializerFeature.WriteEnumUsingName.mask;
// 全局设置,枚举的序列化使用 ordinal()
JSON.DEFAULT_GENERATE_FEATURE &= ~SerializerFeature.WriteEnumUsingName.mask;
// 序列化为JSON输出,枚举值为 ordinal()
User user = new User(1, Gender.BOY);
String jsonString = JSON.toJSONString(user);
System.out.println(jsonString); // {"gender":0,"id":1}
// 反序列化为对象
user = JSON.parseObject(jsonString, User.class);
System.out.println(user.getGender()); // BOY
特殊设置
只想针对某一次序列化生效。只需要调用JSON.toJSONString
的重载方法,添加配置就行。
public static String toJSONString(Object object, int defaultFeatures, SerializerFeature... features)
// 序列化为JSON输出,本次把枚举值序列化为 ordinal()
User user = new User(1, Gender.BOY);
String jsonString = JSON.toJSONString(user, JSON.DEFAULT_GENERATE_FEATURE & ~SerializerFeature.WriteEnumUsingName.mask);
System.out.println(jsonString); // {"gender":0,"id":1}
// 反序列化为对象
user = JSON.parseObject(jsonString, User.class);
System.out.println(user.getGender()); // BOY
序列化为自定义属性
很多人也喜欢给枚举定义一个私有的属性,序列化为JSON时,希望以这个属性值作为value,这个时候就需要自己定义JSON的序列化和反序列化实现了。Fastjson提供了2个接口。用户控制序列化和反序列化行为,这个实在是太简单,这里不多说。看代码
- ObjectSerializer
- ObjectDeserializer
序列化器的定义
import java.io.IOException;
import java.lang.reflect.Type;
import com.alibaba.fastjson.serializer.JSONSerializer;
import com.alibaba.fastjson.serializer.ObjectSerializer;
public class GenderEnumSerializer implements ObjectSerializer {
@Override
public void write(JSONSerializer serializer, Object object, Object fieldName, Type fieldType, int features) throws IOException {
// 强制把值转换为Gender
Gender gender = (Gender) object;
// 序列化为自定义的name属性,输出就行
serializer.out.writeString(gender.getName());
}
}
反序列化器的定义
import java.lang.reflect.Type;
import com.alibaba.fastjson.parser.DefaultJSONParser;
import com.alibaba.fastjson.parser.JSONToken;
import com.alibaba.fastjson.parser.deserializer.ObjectDeserializer;
public class GenderEnumDeserializer implements ObjectDeserializer {
@SuppressWarnings("unchecked")
@Override
public <T> T deserialze(DefaultJSONParser parser, Type type, Object fieldName) {
// 解析值为字符串
String value = parser.parseObject(String.class);
// 遍历所有的枚举实例
for (Gender gender : Gender.values()) {
if (gender.getName().equals(value)) {
// 成功匹配,返回实例
return (T) gender;
}
}
// 没有匹配到,可以抛出异常或者返回null
return null;
}
@Override
public int getFastMatchToken() {
// 仅仅匹配字符串类型的值
return JSONToken.LITERAL_STRING;
}
}
对象 & 枚举的定义
enum Gender {
BOY("男"), GIRL("女"), UNKNOW("不知道");
public final String name;
Gender(String name) {
this.name = name;
}
public String getName() {
return name;
}
}
class User {
private Integer id;
// 标识注解,指定枚举的序列化。反序列化实现类
@JSONField(serializeUsing = GenderEnumSerializer.class, deserializeUsing = GenderEnumDeserializer.class)
private Gender gender;
public User() {
}
public User(Integer id, Gender gender) {
super();
this.id = id;
this.gender = gender;
}
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Gender getGender() {
return gender;
}
public void setGender(Gender gender) {
this.gender = gender;
}
}
测试
public class MainTest {
public static void main(String[] args) throws Exception {
// 序列化为JSON输出,枚举值为 getName()
User user = new User(1, Gender.UNKNOW);
String jsonString = JSON.toJSONString(user);
System.out.println(jsonString); // {"gender":"不知道","id":1}
// 反序列化为对象
user = JSON.parseObject(jsonString, User.class);
System.out.println(user.getGender()); // UNKNOW
}
}
最后
很显然,自定义 ObjectSerializer /ObjectDeserializer 的方式最为灵活,可以考虑抽象一个接口出来,让所有的枚举都实现接口。这样针对接口编写ObjectSerializer /ObjectDeserializer实现,就可以很好的复用了。
本文首发:https://springboot.io/t/topic...
fastjson进行json的解析和序列化
参考技术Afastjson是阿里巴巴的开源JSON解析库,它可以解析JSON格式的字符串,支持将JavaBean序列化为JSON字符串,也可以从JSON字符串反序列化到JavaBean。速度快:相对其他JSON库的特点是快使用简单:api简单功能完善:支持泛型,支... 查看详情
fastjson处理double的精度问题
项目中使用fastjson来处理json格式,当前使用的版本为1.1.37。在和其它系统交互时,将一个json串传给了对方,原值为5.0,json处理后格式为:{"dou",5};结果对方处理该串报错了,原因是他将串整理转成Map,在取值时强制转为了Double,... 查看详情
springboot处理fastjson的多层嵌套
我要获取json的信息,但是问题是json嵌套了太多层,刚开始我想到阿里巴巴的fastjson工具导入依赖<dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.66</version></ 查看详情
genson和gson,fastjson比有啥优势吗
gson和fastjson我都在项目使用过了,相比较而言,gson对字段的处理更细腻一些,有版本号的概念,相对更灵活,值得注意是,gson直接入侵字段,则不是setget方法;fastjson速度更快,但字段的处理不够灵活,特别是处理同一个Javabean... 查看详情
当java枚举遇到位掩码,还能这么玩?(代码片段)
相信大家都用过Fastjson,阿里的一个开源JSON库,在阿里系的开源项目里应用的非常广泛。虽然有时候也被戏称“沉的快”,但Fastjson从功能丰富度、易用性、源码设计角度来看,都是一款十分优秀的工具库。在使... 查看详情
当java枚举遇到位掩码,还能这么玩?(代码片段)
相信大家都用过Fastjson,阿里的一个开源JSON库,在阿里系的开源项目里应用的非常广泛。虽然有时候也被戏称“沉的快”,但Fastjson从功能丰富度、易用性、源码设计角度来看,都是一款十分优秀的工具库。在使... 查看详情
spark处理json数组fastjson
json数据格式:[{"studentName":"lily","studentAge":12},{"studentName":"lucy","studentAge":15}]pom:<dependency><groupId>org.apache.spark</groupId><artifactId>spark-core_2.11</artif 查看详情
解决com.alibaba.fastjson.jsonexception:autotypeisnotsupport异常处理(代码片段)
最近在使用spring-data-redis时,使用fastjson的序列化方式GenericFastJsonRedisSerializer可以正常序列化,但在反序列化时发生了如下异常com.alibaba.fastjson.JSONException:autoTypeisnotsupport.com.hongshu.groovy.dto.Account。 仔细阅读了f 查看详情
使用fastjson处理返回字符串中的转义符
参考技术A问题:项目中使用的是FastJsonHttpMessageConverter来格式化返回数据,在使用ueditor自定义config时里面包含\n等转义符,结果返回的数据中转义符没有处理掉。解决方法:在FastJsonHttpMessageConverter之前加上StringHttpMessageConverter... 查看详情
fastjson输出null为空字符串
JSONObject.toJSONString(Objectobject,SerializerFeature...features)SerializerFeature有用的一些枚举值QuoteFieldNames———-输出key时是否使用双引号,默认为trueWriteMapNullValue——–是否输出值为n 查看详情
fastjsonnull值处理
偶然用到fastjson转换json在前台用js解析竟然某些字段没有,曾经用过gson。联想到是不是相似gson默认将null值不显示了,找了下资料果真如此直接上代码吧importjava.util.HashMap;importjava.util.Map;importcom.alibaba.fastjson.JSONObject;importcom.alibaba.... 查看详情
androidjson解析架包(阿里巴巴的fastjson)处理是报异常。
异常显示:com.alibaba.fastjson.JSONException:exepct'[',but怎么解决。参考技术A应该是json字符串的格式有问题吧,先找找看有问题没有,没有的话再看解析的时候哪里有逻辑问题没有,不行就把报错的那几行代码和json字符串贴出来... 查看详情
fastjson使用过程中的坑
...朋友可以关注我的博客http://zwgeek.com最近在工作中用到了fastjson,遇到了一些坑,在这里总结一下。简介首先,介绍一下fastjson。fastjson是由alibaba开源的一套json处理器。与其他json处理器(如Gson,Jackson等) 查看详情
httpclient.jar和fastjson.jar发生冲突了,怎么解决?两个包都想要
参考技术Agson和fastjson我都在项目使用过了,相比较而言,gson对字段的处理更细腻一些,有版本号的概念,相对更灵活,值得注意是,gson直接入侵字段,则不是setget方法;fastjson速度更快,但字段的处理不够灵活,特别是处理同... 查看详情
PetaPoco 是不是处理枚举?
】PetaPoco是不是处理枚举?【英文标题】:DoesPetaPocohandleenums?PetaPoco是否处理枚举?【发布时间】:2011-10-1414:13:41【问题描述】:我正在尝试使用PetaPoco将表格转换为POCO。在我的表中,我有一个名为TheEnum的列。此列中的值是表示... 查看详情
通过装饰覆盖一个特定枚举的全局 Json.NET 枚举处理
】通过装饰覆盖一个特定枚举的全局Json.NET枚举处理【英文标题】:OverrideglobalJson.NETenumhandlingforoneparticularenumviadecoration【发布时间】:2015-04-1023:09:27【问题描述】:我有一堆枚举,我希望Json.NET将它们序列化为驼峰式字符串。我... 查看详情
fastjson使用方法大全
参考资料:http://www.java265.com/fastjson/下文是市面上最全面的一篇fastjson的文章,具体内容如下所示:一、Fastjson简介Fastjson是一个Java语言编写的JSON处理器。1、遵循http://json.org标准,为其官方网站收录的参考实现之 查看详情
解决com.alibaba.fastjson.jsonexception:autotypeisnotsupport异常处理(代码片段)
最近在使用spring-data-redis时,使用fastjson的序列化方式GenericFastJsonRedisSerializer可以正常序列化,但在反序列化时发生了如下异常com.alibaba.fastjson.JSONException:autoTypeisnotsupport.com.hongshu.groovy.dto.Account。 仔细阅读了fastjson.ParserCon... 查看详情