SpringBoot项目中忽略某属性返回数据给前端

 更新时间:2024年05月02日 11:02:08   作者:玉成226  
在Spring Boot中,保护敏感信息和减少数据传输是很重要的,我们可以使用多种方法来忽略返回数据中的字段,无论是使用@JsonIgnore注解、Projection投影、@JsonIgnoreProperties注解还是自定义序列化器,都能达到我们的目的,在实际应用中,根据具体场景和需求选择合适的方法

在使用Spring Boot开发应用程序时,经常会遇到需要返回DTO(数据传输对象)的情况,而不是返回实体类。有时候,实体类中的某些字段可能包含敏感信息或不需要传递给客户端。在这种情况下,我们需要找到一种方法来忽略这些字段并只返回需要的数据。

一、忽略实体类中的属性

1、@JsonIgnore

@JsonIgnore注解是Jackson库中的一个注解,用于在实体类向前台返回数据时忽略不想传递给前台的属性或接口。当你在Java类的某个属性或方法上添加@JsonIgnore注解时,Jackson在将对象序列化为JSON时将会忽略这个属性或方法,也就是说这个属性或方法将不会出现在生成的JSON字符串中。这对于那些你不希望暴露给前端的属性(如密码、敏感信息等)非常有用。

例如,在User类中,如果你有一个password属性,并且你不希望在前台看到这个属性,你可以在password属性上添加@JsonIgnore注解。

此外,还有一个类似的注解叫做@JsonIgnoreProperties,这是一个类注解,用于在json序列化时将java bean中的一些属性忽略掉,序列化和反序列化都受影响。你可以在类上添加这个注解,并指定要忽略的属性名列表。

需要注意的是,如果在使用fastJson而不是Jackson作为JSON处理库,那么@JsonIgnore注解可能不会生效。在fastJson中,你需要使用@JSONField(serialize = false)注解来达到相同的效果。

2、@JSONField(serialize = false)

@JSONField注解是阿里巴巴fastjson库中的注解,用于控制Java对象与JSON字符串之间的转换。它可以用于控制序列化和反序列化过程中的一些细节,例如日期格式、序列化顺序、字段名称等。

@JSONField注解可以作用在方法、属性以及方法中的参数上。在JSONField注解中,name属性用来指定JSON串中key的名称。例如,@JSONField(name = “id”)表示将Java对象中的userId字段映射到JSON字符串中的"id"字段。

此外,@JSONField注解还有其他一些常用的属性,如:

format:用于指定日期或数字的格式。例如,@JSONField(format = “yyyy-MM-dd HH:mm:ss”)表示将Java对象中的createTime字段按照指定的日期格式转换为JSON字符串。serialize:用于指定是否序列化某个字段。例如,@JSONField(serialize = false)表示不序列化某个字段。ordinal:用于指定序列化顺序,数值越小越先序列化。

通过使用@JSONField注解,你可以灵活地控制Java对象与JSON字符串之间的转换,实现更复杂的序列化和反序列化需求。

3、@JsonInclude

@JsonInclude 是 Jackson 库中的一个注解,它用于定制在序列化(即将 Java 对象转换为 JSON 字符串)过程中哪些属性应该被包含在内。这个注解可以用于类、方法或字段,以定义如何包含字段值。

Jackson 提供了几种不同的 Include 策略:

JsonInclude.Include.ALWAYS:始终包含属性,无论其值是什么。
JsonInclude.Include.NON_ABSENT:包含非空的(non-absent)属性。这相当于 NON_NULL(非空)加上非空集合、非空映射等。JsonInclude.Include.NON_DEFAULT:包含其值不等于字段默认值的属性。这需要注意,对于基本数据类型(如 int、long 等),它们的默认值通常是 0 或 false,而对于包装类型(如 Integer、Long 等),默认值是 null。
JsonInclude.Include.NON_EMPTY:对于字符串,只包含非空字符串;对于集合、数组和映射,只包含非空集合。JsonInclude.Include.NON_NULL:只包含非空(non-null)属性。
JsonInclude.Include.CUSTOM:使用自定义的包含策略。

例如,如果你有一个类并且你只想在序列化时包含非空的字段,你可以这样做:

import com.fasterxml.jackson.annotation.JsonInclude;  
@JsonInclude(JsonInclude.Include.NON_NULL)  
public class MyObject {  
    private String name;  
    private Integer age;  
    // getters and setters  
}

在这个例子中,如果 name 或 age 字段的值为 null,那么在序列化 MyObject 的实例为 JSON 字符串时,这些字段将不会被包含在内。

这个注解非常有用,因为它可以帮助你控制生成的 JSON 字符串的大小和可读性,尤其是在你有很多可选字段或嵌套对象的情况下。

二、忽略实体类中的方法返回值

@Transient注解是Java EE规范提供的javax.persistence包定义的注解之一。这个注解的作用是指定该属性或字段不是永久的,即告诉MyBatis不需要将该字段映射为数据库表的列,也就是标记实体类中不需要持久化到数据库的字段。

@Transient注解的使用不仅限于实体类上有@Table注解的属性,它可以用在任何实体类的字段或者方法上。无论实体类是否有@Table注解,只要被@Transient注解标记的字段或方法都会被忽略,不进行数据库映射操作。

此外,@Transient注解也可以用于Java序列化过程中,用于标记不希望序列化的字段。当对象被序列化时,被标记为@Transient的字段将被忽略。

总的来说,@Transient注解的主要作用是在Java EE的持久化和序列化过程中,告诉系统哪些字段或属性不需要被处理。

@Data
public class ResourceParam {
    private String field1;
    private String field2;
    private String field3;
    @Transient
    public String getTest() {
        return “string”;
    }
}

总结

在Spring Boot中,我们可以使用多种方法来忽略返回数据中的字段。无论是使用@JsonIgnore注解、Projection投影、@JsonIgnoreProperties注解还是自定义序列化器,都能达到我们的目的。

在实际应用中,根据具体场景和需求选择合适的方法。请记住,保护敏感信息和减少数据传输是很重要的。通过忽略不必要的字段,我们可以提高系统的性能和安全性。

相关文章

  • Spring框架之IOC介绍讲解

    Spring框架之IOC介绍讲解

    IOC-Inversion of Control,即控制反转。它不是什么技术,而是一种设计思想。这篇文章将为大家介绍一下Spring控制反转IOC的原理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • JAVA中AES对称加密和解密过程

    JAVA中AES对称加密和解密过程

    这篇文章主要为大家详细介绍了JAVA中AES对称加密和解密过程,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • MyBatis复杂Sql查询实现示例介绍

    MyBatis复杂Sql查询实现示例介绍

    在利用mybatis做查询的时候,一般返回结果用resulttype,这种情况必须是查询的结果在对应 的pojo类中有对应的,一般都是单表查询,但是对于一些复杂的情况,比如需要用到多表查询的时候,resultType不再适用,此时一般用resultMap来表示返回的结果
    2022-12-12
  • SpringBoot整合MinIO实现文件存储系统的代码示例

    SpringBoot整合MinIO实现文件存储系统的代码示例

    在现代的应用程序中,文件存储和管理是一个常见的需求,MinIO是一个开源的对象存储系统,与Spring Boot框架结合使用,可以快速构建高性能的文件存储系统,本文将介绍如何使用Spring Boot和MinIO来实现文件存储系统
    2023-06-06
  • Java 值传递和引用传递详解及实例代码

    Java 值传递和引用传递详解及实例代码

    这篇文章主要介绍了 Java 值传递和引用传递详解及实例代码的相关资料,需要的朋友可以参考下
    2017-03-03
  • Java OCR tesseract 图像智能文字字符识别技术实例代码

    Java OCR tesseract 图像智能文字字符识别技术实例代码

    这篇文章主要介绍了Java OCR tesseract 图像智能文字字符识别技术实例代码,非常具有实用价值,需要的朋友可以参考下
    2017-06-06
  • java的线程池框架及线程池的原理

    java的线程池框架及线程池的原理

    这篇文章主要介绍了java的线程池框架及线程池的原理的相关资料,需要的朋友可以参考下
    2017-03-03
  • 如何解决@Data和@Builder的冲突问题

    如何解决@Data和@Builder的冲突问题

    在使用@Data和@Builder注解时,可能会导致无法使用无参构造方法创建实体类实例的问题,本文提出了两种解决方法:一是手动添加无参构造并使用@Tolerate注解兼容;二是同时添加@AllArgsConstructor和@NoArgsConstructor注解,既添加无参构造也添加全参构造
    2024-10-10
  • 带你深入概括Java!六、方法和方法重载!(推荐)

    带你深入概括Java!六、方法和方法重载!(推荐)

    这篇文章主要介绍了Java方法和方法重载,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • Java和Python现在都挺火,我应该怎么选?

    Java和Python现在都挺火,我应该怎么选?

    这篇文章主要介绍了Java和Python现在都挺火,我应该怎么选?本文通过全面分析给大家做个参考,需要的朋友可以参考下
    2020-07-07

最新评论