真正的快乐是内在的,它只有在人类的心灵里才能发现。——布雷默
相信关于FastJson大伙都不陌生
今天聊聊fastjson
的这个注解@JSONField
首先它可以放到方法上
例如我们pojo
的getter
和setter
等
其次用的最多的是放到属性上
例如我这里新建一个POJO
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
private static class Student implements Serializable {
private static final long serialVersionUID = -3289647584974663707L;
private String name;
private Integer age;
private String job;
private GenderEnum gender;
private Date birthday;
private String json;
}
这里的性别枚举
@Getter
@AllArgsConstructor
public enum GenderEnum {
FEMALE("女", 0),
MALE("男", 1);
private final String name;
private final Integer code;
}
写一个main
函数
public static void main(String[] args) {
Instant from = LocalDateTime.parse("2021-01-09 00:00:00", DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss", Locale.ENGLISH)).toInstant(ZoneOffset.MAX);
Student supa = Student.builder().name("supa").age(20).gender(GenderEnum.MALE).birthday(Date.from(from)).json("{\"word\":\"xxx\"}").build();
String serializeStr = JSON.toJSONString(supa);
System.out.println(serializeStr);
Student student = JSON.parseObject(serializeStr, Student.class);
System.out.println(student);
}
先运行一下
然后开始一一介绍@JSONField
的属性
第一个ordinal
可以指定序列化后的json
字符串属性顺序
例如我们稍微配置一下
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
private static class Student implements Serializable {
private static final long serialVersionUID = -3289647584974663707L;
@JSONField(ordinal = 3)
private String name;
@JSONField(ordinal = 1)
private Integer age;
private String job;
@JSONField(ordinal = 2)
private GenderEnum gender;
private Date birthday;
private String json;
}
然后再次运行可以看到我们序列化后的JSON
串属性顺序按照升序排序了
接下来是name
它可以指定我们序列化/反序列化属性的名称
我们在name
上加一个
可以看到之前的name
序列化后变成了studentName
下一个是format
对于日期格式,我们可以使用它去指定日期格式
例如
@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
private static class Student implements Serializable {
private static final long serialVersionUID = -3289647584974663707L;
@JSONField(ordinal = 3, name = "studentName")
private String name;
@JSONField(ordinal = 1)
private Integer age;
private String job;
@JSONField(ordinal = 2)
private GenderEnum gender;
@JSONField(format = "yyyy年MM月dd日E")
private Date birthday;
private String json;
}
序列化后结果就是这样
然后是serialize
:默认为true
,如果为false
,序列化时会忽略该属性
然后是deserialize
:默认为true
,如果为false
,反序列化时会忽略该属性
然后是serialzeFeatures
,它的值为com.alibaba.fastjson.serializer.SerializerFeature
可以指定一些序列化的选项,例如我们值为null
时序列化为空串
parseFeatures
则是可以指定一些转换选项,值为com.alibaba.fastjson.parser.Feature
这两个的值都可以是多个
下面是label
,这个跳过
jsonDirect
针对值为json
字符串的属性,为true
则序列化,为false
则不序列化,默认为false
然后是serializeUsing
指定序列化时使用哪个序列化器
我们自定义一个
/**
* 性别序列化
*/
public static class GenderEnumParser implements ObjectSerializer {
@Override
public void write(JSONSerializer serializer, Object object, Object fieldName, Type fieldType, int features) throws IOException {
Integer genderCode = null;
if (fieldType.getTypeName().equals(GenderEnum.class.getName())) {
genderCode = ((GenderEnum) object).getCode();
}
serializer.write(genderCode);
}
}
然后执行
使用deserializeUsing
指定反序列化器一样的
public static class GenderEnumFormatter implements ObjectDeserializer {
@Override
public <T> T deserialze(DefaultJSONParser parser, Type type, Object fieldName) {
JSONObject jsonObject = JSON.parseObject(parser.getInput());
Integer genderCode = jsonObject.getInteger(String.valueOf(fieldName));
return (T) Arrays.stream(GenderEnum.values()).filter(gender -> gender.getCode().equals(genderCode)).findFirst().orElse(null);
}
@Override
public int getFastMatchToken() {
return 0;
}
}
然后是alternateNames
可以取别名,例如json
字符串中,可能叫studentName
,也可能叫myName
他们都要反序列化后放入name
我们就可以使用它