Jackson 各种注解使用示例

news/2024/5/14 6:46:25

参考资料

  1. Jackson使い方メモ

目录

  • 一. @JsonIgnore
  • 二. @JsonIgnoreProperties
  • 三. @JsonProperty
    • 3.1 作用于entity属性上,指定json对象属性名
    • 3.2 作用于entity方法上,指定json对象属性名
  • 四. @JsonFormat
    • 4.1 日期格式化
    • 4.2 数字格式化
    • 4.3 枚举类返回code
  • 五. @JsonCreator注解 枚举类接收前台提交数据
    • 5.1 枚举类和接收数据entity的定义
    • 5.2 后台枚举类接收前台的数据
    • 5.3 后台枚举类型的数据返回给前台
  • 六. @JsonAlias
  • 七. @JsonInclude


一. @JsonIgnore

  • 在序列化和反序列化 JSON 数据时,忽略指定的属性。
import com.fasterxml.jackson.annotation.*;
import lombok.Data;@Data
public class Test34Entity {@JsonIgnoreprivate String id;private String name;private String content;
}
  • 返回数据给前台
@PostMapping("/get_data")
public ResponseEntity<Test34Entity> getData(@RequestBody Test34Entity data) {Test34Entity entity  = new Test34Entity();// 在此处设定了id属性entity.setId("1355930");entity.setName("贾飞天");entity.setContent("内容");return ResponseEntity.ok(entity);
}

⏹由于给id属性添加了@JsonIgnore注解,所以id并没有返回给前台。

在这里插入图片描述


二. @JsonIgnoreProperties

  • 同时指定多个需要忽略的属性
import com.fasterxml.jackson.annotation.*;
import lombok.Data;@Data
@JsonIgnoreProperties({"id", "content"})
public class Test34Entity {private String id;private String name;private String content;
}

⏹可以看到,因为id和content属性被忽略,所以只有name属性被返回到了前台。

在这里插入图片描述


三. @JsonProperty

3.1 作用于entity属性上,指定json对象属性名

⏹由下图可知,当前台json的属性值和后台实体类属性值不匹配时,可使用@JsonProperty指定

在这里插入图片描述

3.2 作用于entity方法上,指定json对象属性名

⏹部分属性值,后台需要根据既存的属性经过业务判断处理后返回前台,且该属性值最终只有前台需要,后台的业务逻辑中并不需要,此时可以将@JsonProperty注解作用于方法上,用来指定该属性

import com.fasterxml.jackson.annotation.JsonProperty;
import lombok.Data;import java.util.Optional;@Data
public class Test34Entity {private String firstName;private String lastName;// 后台不需要该属性,只有前台才需要此属性// private String fullName;// 指定该方法的返回值作为json的属性,属性名为fullname@JsonProperty("fullName")private String getFullName() {return Optional.ofNullable(this.firstName).orElse("") + Optional.ofNullable(this.lastName).orElse("");}
}

⏹如下图所示,在返回给前台的时候,fullName也被返回。

在这里插入图片描述


四. @JsonFormat

4.1 日期格式化

  • 在Date和YearMonth属性上指定日期字符串的格式
import com.fasterxml.jackson.annotation.*;
import lombok.Data;import java.time.YearMonth;
import java.util.Date;@Data
public class Test34Entity {@JsonFormat(pattern = "yyyy/MM/dd")private Date birthday;@JsonFormat(pattern = "yyyy/MM")private YearMonth yearMonth;
}

⏹由下图可知,日期字符串转换为java实体类中的日期属性类型

在这里插入图片描述

4.2 数字格式化

  • 指定序列化时的数据类型(返回前台的数据类型)
import com.fasterxml.jackson.annotation.JsonFormat;
import lombok.Data;import java.math.BigDecimal;@Data
public class Test34Entity {// 指定序列化时的数据类型是字符串@JsonFormat(shape = JsonFormat.Shape.STRING)private BigDecimal num1;@JsonFormat(shape = JsonFormat.Shape.STRING)private Integer num2;// 未指定序列化时的数据类型private BigDecimal num3;private Integer num4;
}

⏹可以看到,指定了 @JsonFormat(shape = JsonFormat.Shape.STRING)注解的属性,返回前台时的数据类型变为字符串类型。

在这里插入图片描述

4.3 枚举类返回code

详情请参考 5.3 后台枚举类型的数据返回给前台

五. @JsonCreator注解 枚举类接收前台提交数据

5.1 枚举类和接收数据entity的定义

⏹定义一个枚举类

  • Jackson根据@JsonCreator注解所作用的枚举类中的方法,将前台提交的数据转换为枚举类对象
  • fromName方法只是为了根据枚举类的name获取枚举类对象,和枚举类序列化反序列化没有关系
import com.fasterxml.jackson.annotation.JsonCreator;
import java.util.Arrays;public enum SexTypes {男性("1"),女性("2"),保密("3");private String code;SexTypes(String code) {this.code = code;}public String getCode() {return code;}/*根据code获取枚举类对象SpringBoot在将前台数据封装的时候,通过@JsonCreator注解对应的方法指定前台的性别code转换为对应的枚举类*/ @JsonCreatorpublic static SexTypes fromCode(String code) {return Arrays.stream(SexTypes.values()).filter(item -> item.code.equals(code)).findAny().orElse(null);}public static SexTypes fromName(String name) {return Arrays.stream(SexTypes.values()).filter(item -> item.name().equals(name)).findAny().orElse(null);}
}

⏹用来接收前台提交到后台数据的entity

import com.example.jmw.common.enums.SexTypes;
import lombok.Data;@Data
public class Test34Entity {private String id;// 自定义的枚举类private SexTypes sexTypes;
}

5.2 后台枚举类接收前台的数据

在这里插入图片描述

5.3 后台枚举类型的数据返回给前台

⏹在不做任何配置的情况下,默认返回前台的数据是枚举类的名称

在这里插入图片描述
⏹在枚举类上配置@JsonFormat(shape = JsonFormat.Shape.OBJECT),返回给前台的是枚举类的code

@JsonFormat(shape = JsonFormat.Shape.OBJECT)
public enum SexTypes {男性("1"),女性("2"),保密("3");// ...以下代码省略...@JsonCreatorpublic static SexTypes fromCode(String code) {return Arrays.stream(SexTypes.values()).filter(item -> item.code.equals(code)).findAny().orElse(null);}
}

⏹效果如下所示,返回的是枚举类的code

在这里插入图片描述


六. @JsonAlias

  • 作用于实体类的属性上
  • 被标记的属性可以同时接受多个指定的key
import com.fasterxml.jackson.annotation.JsonAlias;
import lombok.Data;@Data
public class Test34Entity {// id 和 userId 都将被封装到此处@JsonAlias({"userId"})private String id;@JsonAlias({"userName"})private String name;
}

⏹效果如下所示,前台json中的key是userId,后台entity的属性值是id,但是通过@JsonAlias注解指定了别名userId,所以成功接受到数据。

在这里插入图片描述

七. @JsonInclude

  • JsonInclude.Include.NON_NULL:指定返回的数据中仅包含非null的数据
import com.fasterxml.jackson.annotation.JsonInclude;
import lombok.Data;@Data
@JsonInclude(JsonInclude.Include.NON_NULL)
public class Test34Entity {private String id;private String name;private String content;
}

⏹由下图可知,content属性为null,但是因为通过@JsonInclude(JsonInclude.Include.NON_NULL)的指定,所以值为null的属性压根就没有返回到前台。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.tangninghui.cn.cn/item-12851.htm

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

Centos7环境下安装MySQL8详细教程

1、下载mysql安装包 下载哪个版本&#xff0c;首先需要确定一下系统的glibc版本&#xff0c;使用如下命令&#xff1a; rpm -qa | grep glibc ​​​​​​​ 2、检查是否安装过mysql ps:因为以前用yum安装过&#xff0c;所以先用yum卸载。如果不是此方式或者没安装过则跳过…

大数据架构

1. 大数据架构全景 Data Sources 数据来源 所有大数据解决方案都始于一个或多个数据源。例如: 应用程序数据存储&#xff0c;如关系型数据库。应用程序生成的静态文件&#xff0c;如Web服务器日志文件。实时数据源&#xff0c;如物联网设备。 Data Storage数据存储 批处理操…

第6章 6.1.2 格式化文本 compose函数(MATLAB入门课程)

讲解视频&#xff1a;可以在bilibili搜索《MATLAB教程新手入门篇——数学建模清风主讲》。​ MATLAB教程新手入门篇&#xff08;数学建模清风主讲&#xff0c;适合零基础同学观看&#xff09;_哔哩哔哩_bilibili 在MATLAB中&#xff0c;存在两个不同版本的compose函数&#xf…

Linux-4 gcc和makefile

Linux编译器-gcc/g使用 1.设计样例 c语言&#xff1a;linux中用的stdc99版本--可能会出现其他问题 c&#xff1a;Linux中用的stdc11--使用c11版本 Linux没有文件格式的区分&#xff0c;但是编译器区分 gcc编译器的文件格式是filename.c g编译器的文件格式是filename.cc或者fil…

百度获评CCIA数据安全和个人信息保护社会责任评价“三星”示范单位

日前&#xff0c;由中国网络安全产业联盟&#xff08;CCIA&#xff09;数据安全工作委员会主办的“促进数据安全合规流通使用”专题研讨会&#xff08;CCIA数安委年度会议&#xff09;成功举办。与会介绍了数据安全和个人信息保护社会责任试点评价工作的开展情况&#xff0c;并…

Set a Light 3D Studio:探索光影艺术的全新维度mac/win中文版

Set a Light 3D Studio 是一款领先的三维建模和渲染软件&#xff0c;它将设计师、艺术家和摄影师的创意想法转化为生动逼真的三维场景。这款软件以其强大的功能和直观的界面&#xff0c;成为行业内众多专业人士的首 选工具。 set.a.light 3D STUDIO中文版软件获取 在Set a Lig…