fastJson的JSONField注解

简介: fastJson的JSONField注解

真正的快乐是内在的,它只有在人类的心灵里才能发现。——布雷默

相信关于FastJson大伙都不陌生

今天聊聊fastjson的这个注解@JSONField

首先它可以放到方法上

例如我们pojogettersetter

其次用的最多的是放到属性上

例如我这里新建一个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

指定序列化时使用哪个序列化器

image-20210314131420096.png

我们自定义一个

/**
 * 性别序列化
 */
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

我们就可以使用它

相关文章
|
7月前
|
XML 搜索推荐 Java
JAXB的常用注解讲解
JAXB的常用注解讲解
|
6月前
|
Java
@SneakyThrows 是 Lombok 库中的一个注解
`@SneakyThrows` 是 Lombok 库中的一个注解,它可以让你在方法签名中省略异常声明,而不需要显式地使用 try-catch 块来处理这些异常。当你使用 `@SneakyThrows` 注解时,Lombok 会自动生成相应的 try-catch 代码,将异常封装成运行时异常(通常是 `RuntimeException` 或其子类)。 这个注解在某些情况下可以简化代码,但请注意,它可能会隐藏潜在的问题,因为异常被转换成了运行时异常,这可能导致调用者无法正确处理这些异常。 下面是一个使用 `@SneakyThrows` 的示例: ```java import lombok.S
430 0
|
7月前
|
安全 Java
深入解析Lombok中的@SneakyThrows注解原理
深入解析Lombok中的@SneakyThrows注解原理
|
8月前
|
IDE Java 数据库连接
Lombok注解大全
这些是Lombok中的一些常见注解,它们可以显著减少Java代码中的冗余代码,提高代码的可读性和可维护性。不过,在使用Lombok之前,请确保你的开发环境已经配置好支持Lombok,通常需要安装相应的插件或进行设置以使IDE(如Eclipse、IntelliJ IDEA)能够正确解析Lombok注解。
109 2
lombok的Tolerate注解
lombok的Tolerate注解
119 0
|
Java Maven
Lombok常用注解
Lombok常用注解
71 0
Zp
|
存储 JSON Java
jackson中@JsonProperty、@JsonIgnore等常用注解总结
jackson中@JsonProperty、@JsonIgnore等常用注解总结
Zp
487 0
|
Java API
lombok注解简介
lombok注解简介
120 0

热门文章

最新文章