java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringBoot忽略属性

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

作者:玉成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注解还是自定义序列化器,都能达到我们的目的。

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

您可能感兴趣的文章:
阅读全文