JsonProperty及JSONField注解的说明

目录

1.JsonProperty

2.JSONField

3.使用场景


1.JsonProperty

1.1.说明

@JsonProperty 注解是 Jackson 库中的一个注解,广泛用于 Java 对象与 JSON 数据之间的序列化和反序列化。Jackson 是一个流行的 Java 库,能够将 Java 对象转换为 JSON 格式,反之亦然。

1.2.主要功能

  1. 指定属性名 : @JsonProperty 可以用来定义 JSON 中使用的属性名称,即使它与 Java 类中的属性名称不同。这在需要匹配特定 JSON 格式时非常有用。

  2. 处理字段的可见性: 可以控制字段是否应该被序列化或反序列化。

  3. 设置默认值: 可以为字段提供默认值。

  4. 标记字段的必需性: 可以指示某个字段在反序列化过程中是必需的

1.3.常见属性

  • value: 指定 JSON 字段的名称。

  • required: 布尔值,指示在反序列化时该字段是否是必需的(默认为 false)。

  • defaultValue: 指定一个默认值,当 JSON 数据中没有提供该字段时使用。

    import com.fasterxml.jackson.annotation.JsonProperty;

    public class Product {

      @JsonProperty(value = "product_id", required = true)
      private int id;
    
      @JsonProperty(value = "product_name", defaultValue = "Unnamed Product")
      private String name;
    
      // Getters and Setters...
    

    }

1.4.示例

import com.fasterxml.jackson.annotation.JsonProperty;

public class User {
    
    @JsonProperty("user_id")
    private int id;

    @JsonProperty("user_name")
    private String name;

    @JsonProperty("user_email")
    private String email;

    // Getters and Setters
    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }
}

给定上面的 User 类,下面是其对应的 JSON 表示:

{
    "user_id": 1,
    "user_name": "John Doe",
    "user_email": "john.doe@example.com"
}

2.JSONField

2.1说明

@JSONField 是一个来自于阿里巴巴的 Fastjson 库的注解,主要用于处理 Java 对象与 JSON 数据之间的序列化和反序列化。Fastjson 是一个高性能的 Java 语言编写的 JSON 处理工具。一般使用fastjson2。

2.2主要功能

  1. 指定字段名称 : @JSONField 可以用来定义在 JSON 中使用的属性名称,即使它与 Java 类中的属性名称不一致。这对于需要匹配特定 JSON 格式的场景非常有用。

  2. 控制序列化/反序列化 : 可以控制某个字段是否参与序列化和反序列化。例如,可以通过设置 serializedeserialize 属性为 false 来排除该字段。

  3. 格式化日期: 可以指定日期字段在 JSON 中的格式,这对于日期类型的字段尤为重要。

  4. 定义默认值: 在反序列化时,可以指定默认值,以便当 JSON 数据中缺少该字段时使用。

2.3常用属性

  • name: 指定 JSON 字段的名称。

  • serialize: 布尔值,指示该字段是否参与序列化(默认为 true)。

  • deserialize: 布尔值,指示该字段是否参与反序列化(默认为 true)。

  • format: 用于格式化时间字段,例如 "yyyy-MM-dd"

    import com.alibaba.fastjson.annotation.JSONField;

    public class Product {

      @JSONField(name = "product_id", serialize = true, deserialize = true)
      private int id;
    
      @JSONField(name = "product_name", defaultValue = "Unnamed Product")
      private String name;
    
      @JSONField(name = "created_at", format = "yyyy-MM-dd HH:mm:ss")
      private Date createdAt;
    
      // Getters and Setters...
    

    }

2.4示例

import com.alibaba.fastjson.annotation.JSONField;

public class User {
    
    @JSONField(name = "user_id")
    private int id;

    @JSONField(name = "user_name")
    private String name;

    @JSONField(name = "user_email")
    private String email;

    // Getters and Setters
    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }
}

使用上面的 User 类,下面是其对应的 JSON 表示:

{
    "user_id": 1,
    "user_name": "John Doe",
    "user_email": "john.doe@example.com"
}

3.使用场景

避免使用lombok的data注解,导致前端接收的json内容的key和后端中bean的id不一致的问题,可以使用上面两个注解,当然也可以手写get set方法,避免此问题

相关推荐
松树戈3 分钟前
JS推荐实践
开发语言·javascript·ecmascript
qq_429856574 分钟前
idea启动服务报错Application run failed
java·ide·intellij-idea
瑞雨溪6 分钟前
java中的this关键字
java·开发语言
J不A秃V头A14 分钟前
Redisson 中开启看门狗(watchdog)机制
java·分布式锁·看门狗
草字16 分钟前
uniapp input限制输入负数,以及保留小数点两位.
java·前端·uni-app
李迟17 分钟前
某Linux发行版本无法使用nodejs程序重命名文件问题的研究
java·linux·服务器
MapleLea1f29 分钟前
26届JAVA 学习日记——Day14
java·开发语言·学习·tcp/ip·程序人生·学习方法
小汤猿人类30 分钟前
SpringTask
开发语言·python
没有黑科技35 分钟前
基于web的音乐网站(Java+SpringBoot+Mysql)
java·前端·spring boot
爪哇学长37 分钟前
解锁API的无限潜力:RESTful、SOAP、GraphQL和Webhooks的应用前景
java·开发语言·后端·restful·graphql