Java開發中POJO和JSON互轉時如何忽略隱藏字段


1. 前言

Java開發中有時候某些敏感信息我們需要屏蔽掉,不能被消費這些數據的客戶端知道。通常情況下我們會將其設置為null或者空字符 "",其實還有其它辦法,如果你使用了Jackson的話。接下來我將以一個實際場景來告訴你可以怎么做。

2. Jackson如何忽略字段

這里都以JSON序列化為例。假如我們在業務中需要返回用戶信息,已有的POJO是這樣的:

import lombok.Data;

/**
 * @author felord.cn
 */
@Data
public class UserInfo {
    /**
     * userid
     */
    private String userId;
    /**
     * 用戶名
     */
    private String username;
    /**
     * 密鑰串
     */
    private String secret;
    /**
     * 地址信息
     */
    private String address;
}

業務場景:第三方通過用戶的userId來獲取用戶的信息,但是密鑰串secret顯然不能讓第三方知道,通常最容易想到的方法是將secret字段設置為null或者""。如果業務需要批量提供用戶信息,即List<UserInfo>,我們總不能每次都要遍歷一遍吧。Spring Boot內置的Jackson可以很方便的幫我們處理這個問題。

使用@JsonIgnore注解

Jackson提供了一個@JsonIgnore注解,將它標記到需要被忽略的字段上或者對應的getter方法或者setter方法上就可以實現對該字段的屏蔽。就像下面這樣標記:

     @JsonIgnore
    private String secret;
   // 對應json 樣例  {"userId":"100000","username":"felord.cn","address":"cn"}

無論是序列化(將POJO轉為JSON)還是反序列化((將JSON轉為POJO),secret都會被忽略。

使用@JsonIgnoreProperties注解

這個注解比@JsonIgnore更加強大一些,通常該注解標記到POJO之上,它有更多的能力:

  • 忽略多個字段,配置value屬性即可。
  • 忽略未知的屬性,配置ignoreUnknowntrue,默認不忽略。
  • 允許忽略字段被序列化,配置allowGetterstrue,序列化的時候不會被忽略。
  • 允許忽略字段被反序列化,配置allowSetterstrue,反序列化的時候不會被忽略。

例如我們要忽略UserInfo中的secretaddress,我們可以這樣配置:

@JsonIgnoreProperties({"secret", "address"})

使用@JsonProperty注解

需要Jackson版本不低於2.6

這個注解出鏡率還是非常高的,通常為了給JSON的字段起別名或者設置默認值使用。比如UserInfo中的userId想對應JSON中的user_id,我們可以:

@JsonProperty(value = "user_id")
private String userId;

在2.6版本以后,這個注解也能實現忽略字段的作用。它有個access屬性,用來指定在序列化(“讀取”)和反序列化(“寫”)期間訪問權限(這里的讀寫是以屬性為視角)。它由枚舉Access定義:

public enum Access
{
    /**
     * 無論是序列化還是反序列化都會根據配置自動的處理,默認值。
     */
    AUTO,

    /**
     * 意味着該屬性只能在進行序列化時讀取(通過“ getter”方法訪問的值,或者從字段中讀取),而在反序列化      * 期間不能寫入(設置)。換句話說,這將反映“只讀POJO”,其中包含的值可以讀取但不能寫入。
     */
    READ_ONLY,

    /**
     * 意味着該屬性只能作為反序列化的一部分寫入(設置)(使用“ setter”方法,或分配給Field,或作為          * Creator參數傳遞),而不會被讀取(獲取)以進行序列化,即,該屬性的值不包括在序列化中。
     */
    WRITE_ONLY,

    /**
     * 可讀可寫,READ_ONLY與WRITE_ONLY的合並效果。
     */
    READ_WRITE;
}

從這個注解中我們可以知道,如果你想在POJOJSON時忽略secret字段,就可以這么寫:

@JsonProperty( access = JsonProperty.Access.WRITE_ONLY)
private String secret;

使用@JsonIgnoreType注解

這個注解是用來直接忽略類型的,如果上面的UserInfo是另外一個POJO的屬性,我們不希望它被序列化和反序列化,那么就可以:

@JsonIgnoreType
public class UserInfo {
   // 省略
}

3. 總結

目前大概可知的Jackson有這么四種的忽略屬性的方式,它們有各自的使用場景,你可以根據自己的情況選擇使用。好了今天的分享就到這里,多多關注:碼農小胖哥,獲取更多的編程干貨。

關注公眾號:Felordcn 獲取更多資訊

個人博客:https://felord.cn


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM