自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

絕了!Spring Boot憑@JsonView注解,強(qiáng)大到逆天

開發(fā) 前端
@JsonView?它是 Jackson 庫(kù)中的一個(gè)強(qiáng)大注解。通過定義不同的視圖類(通常為接口或類),并在實(shí)體類的字段上使用?@JsonView?注解標(biāo)記該字段在哪個(gè)視圖中可見,同時(shí)在控制器方法中通過?@JsonView?注解指定返回的視圖,就可以靈活控制返回的字段內(nèi)容,實(shí)現(xiàn)了根據(jù)不同場(chǎng)景動(dòng)態(tài)選擇序列化字段的目的,大大提高了代碼的簡(jiǎn)潔性和可維護(hù)性。

環(huán)境:SpringBoot3.4.2

1. 簡(jiǎn)介

在基于 RESTful 架構(gòu)的 Web 應(yīng)用開發(fā)里,后端服務(wù)與前端客戶端之間的數(shù)據(jù)交互通常采用 JSON 格式。然而,不同的業(yè)務(wù)場(chǎng)景對(duì)數(shù)據(jù)的需求存在差異。例如,在用戶列表展示場(chǎng)景中,僅需返回用戶的基本信息,如用戶名、頭像等;而在用戶詳情查看場(chǎng)景中,則需要返回用戶的全部信息,包括敏感信息如密碼等。

為滿足這種多樣化的數(shù)據(jù)需求,傳統(tǒng)方式可能需要?jiǎng)?chuàng)建多個(gè)數(shù)據(jù)傳輸對(duì)象(DTO),分別對(duì)應(yīng)不同的數(shù)據(jù)展示場(chǎng)景,但這會(huì)導(dǎo)致代碼冗余和維護(hù)成本增加。

@JsonView 它是 Jackson 庫(kù)中的一個(gè)強(qiáng)大注解。通過定義不同的視圖類(通常為接口或類),并在實(shí)體類的字段上使用 @JsonView 注解標(biāo)記該字段在哪個(gè)視圖中可見,同時(shí)在控制器方法中通過 @JsonView 注解指定返回的視圖,就可以靈活控制返回的字段內(nèi)容,實(shí)現(xiàn)了根據(jù)不同場(chǎng)景動(dòng)態(tài)選擇序列化字段的目的,大大提高了代碼的簡(jiǎn)潔性和可維護(hù)性。

2. 實(shí)戰(zhàn)案例

2.1 基本使用

實(shí)體類定義

public class User {
  public interface PublicView {} ;
  public interface InternalView extends PublicView {} ;
  @JsonView(PublicView.class)
  private Long id ;
  @JsonView(PublicView.class)
  private String name ;
  @JsonView(PublicView.class)
  private String address ;
  @JsonView(InternalView.class)
  private String password ;
  @JsonView(InternalView.class)
  private String idCard ;
  @JsonView(PublicView.class)
  private String email ;
  // getters, setters
}

Controller接口

@RestController
@RequestMapping("/users")
public class UserController {
  @JsonView(User.PublicView.class)
  @GetMapping("/query")
  public User query() {
    return new User(1L, "pack", "四川烏魯木齊市", "123456", 
        "152528202504096514", "pack@qq.com");
  }
}

訪問接口輸出如下:

圖片圖片

如果將接口上的@JsonView修改為InternalView輸出如下:

圖片圖片

所有的字段都輸出了。

注意,如果你有字段沒有添加@JsonView注解,那么將不會(huì)被輸出(默認(rèn)情況)。

2.2 編程方式

如果你想以編程方式實(shí)現(xiàn)上述功能(而不是聲明一個(gè) @JsonView 注解),可以將返回值用 MappingJacksonValue 對(duì)象包裹起來,并利用它來指定序列化視圖:

@GetMapping("/getUser")
public MappingJacksonValue getUser() {
  User user = new User(1L, "pack", "四川烏魯木齊市", "123456", 
      "152528202504096514", "pack@qq.com") ;
  MappingJacksonValue value = new MappingJacksonValue(user);
  value.setSerializationView(User.PublicView.class);
  return value;
}

訪問該接口,輸出結(jié)果:

圖片圖片

2.3 視圖Json

對(duì)于依賴視圖的控制器,只需將序列化視圖類添加到model中即可,如下例所示:

@Controller
public class UserViewController {
  @GetMapping("/userview")
  public ModelAndView userView(Model model) {
    User user = new User(1L, "pack", "四川烏魯木齊市", "123456", 
      "152528202504096514", "pack@qq.com") ;
    model.addAttribute("user", user) ;
    model.addAttribute(JsonView.class.getName(), User.PublicView.class) ;
    return new ModelAndView(new MappingJackson2JsonView()) ;
  }
}

我們以JsonView的完整類名作為key添加到Model中,最后返回時(shí)定義MappingJacksonJsonView視圖對(duì)象即可控制輸出的字段。

訪問上面接口輸出:

圖片圖片

2.4 限制反序列化

當(dāng)我們不希望某些字段被反序列化時(shí),我們也可以通過該視圖技術(shù)來限制,如下示例:

@PostMapping("/deserialize_json")
public User deserialize(@RequestBody String json) throws Exception {
  ObjectMapper mapper = new ObjectMapper() ;
  User user = mapper
    .readerWithView(User.PublicView.class)
    .forType(User.class)
    .readValue(json) ;
  return user ;
}

請(qǐng)求測(cè)試如下:

圖片圖片

我們的接口并沒有對(duì)password和idCard兩個(gè)字段進(jìn)行反序列化。

2.5 配置默認(rèn)行為

通過上面的示例我們了解到,可以利用 @JsonView 注解來指定字段在哪些視圖下可以被序列化輸出。如果字段未添加 @JsonView 注解,則默認(rèn)情況下該字段不會(huì)被輸出。然而,當(dāng)實(shí)體類的字段數(shù)量較多時(shí),為每個(gè)字段單獨(dú)添加注解會(huì)非常繁瑣。為此,我們可以通過如下配置來更改這一默認(rèn)行為:

spring:
  jackson:
    mapper:
      default-view-inclusion: true

接下來,我們將User修改如下:

public class User {
  private Long id ;
  private String name ;
  private String address ;
  @JsonView(InternalView.class)
  private String password ;
  @JsonView(InternalView.class)
  private String idCard ;
  private String email ;
}

我們將公共字段上的注解去掉,接下來,我們?cè)俅卧L問上面的/users/query接口

圖片圖片

沒有添加注解的字段也可以輸出了(這屬于默認(rèn)字段)。

注:我們的接口上還是需要@JsonView(User.PublicView.class)注解。

責(zé)任編輯:武曉燕 來源: Springboot全家桶實(shí)戰(zhàn)案例源碼
相關(guān)推薦

2025-04-10 00:22:22

Spring@JsonView字段

2025-04-10 00:25:00

Spring@JsonView注解

2023-06-02 16:24:46

SpringBootSSM

2017-08-02 14:44:06

Spring Boot開發(fā)注解

2021-04-13 20:24:57

Spring Boot注解spring

2024-10-14 17:18:27

2024-11-27 09:58:41

Spring模塊化管理方式

2020-11-02 07:00:29

Spring Boo注解自動(dòng)化

2020-03-31 15:03:56

Spring Boot代碼Java

2023-04-17 23:49:09

開發(fā)代碼Java

2025-04-29 07:44:26

配置校驗(yàn)機(jī)制

2019-08-15 10:56:10

WebServletSpring mvc

2012-11-12 15:08:14

搜狗

2017-05-12 15:47:15

Spring BootMybatis Ann Web

2020-09-21 06:54:59

熱部署Spring日志

2020-12-15 10:46:29

事件監(jiān)聽器Spring Boot

2024-11-06 11:33:09

2025-02-26 10:00:00

開發(fā)APIJava

2024-11-01 10:40:32

2025-02-12 08:57:43

Spring動(dòng)態(tài)注冊(cè)組件
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)