成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

優雅地統一處理接口返回值的最佳實踐

開發 前端
通過自定義ResponseBodyAdvice,我們可以實現接口統一返回值的處理,從而提高了接口的可讀性、擴展性和錯誤處理能力。

1. 介紹

如果你正在尋找一種方法來規范化你的RESTful API的返回值,那么這篇文章將是你的理想選擇。通過閱讀這篇文章,你將了解到如何使用Spring ResponseBodyAdvice來改善你的API設計和實現。

為什么要統一接口返回值?

  • 統一規范:通過 ResponseBodyAdvice 可以對所有接口返回值進行統一的包裝,從而制定統一的規范,使得接口返回值更加清晰、易于理解。這對于整個應用程序的接口管理非常有幫助,可以避免不同接口返回值格式不一致的問題。
  • 可讀性增強:通過包裝返回值,可以添加必要的字段,如狀態碼、狀態消息等,使得接口返回值更加易于閱讀和理解。這對于開發者和用戶來說都是非常有益的,可以更方便地了解接口的返回結果。
  • 擴展性:通過 ResponseBodyAdvice 可以很方便地擴展接口返回值的格式,例如添加JSON格式的返回值,而不需要修改原有的接口代碼。這使得應用程序具有更好的擴展性,可以根據需求靈活地添加新的返回值格式。

2. 開發流程

定義統一返回值的包裝類

public class R {
  private Integer code ;
  private Object data ;
  private String message ;
  public R(Integer code, Object data, String message) {
    this.code = code ;
    this.data = data ;
    this.message = message ;
  }
  public static R success(Object data) {
    return new R(200, data, "success") ;
  }
  public static R failure(String message) {
    return new R(500, null, message) ;
  }
}

自定義ResponseBodyAdvice

@RestControllerAdvice
public class PackResponseBodyAdvice implements ResponseBodyAdvice<Object> {
  @Resource
  private ObjectMapper objectMapper ;
  @Override
  public boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType) {
    // 只有返回值不是R類型的時候才通過該Advice進行處理
    return !returnType.getParameterType().equals(R.class) ;
  }
  @Override
  public Object beforeBodyWrite(Object body, MethodParameter returnType, MediaType selectedContentType,
      Class<? extends HttpMessageConverter<?>> selectedConverterType, ServerHttpRequest request,
      ServerHttpResponse response) {
    // 統一返回值處理
    return R.success(body) ;
  }


}

測試接口

@RestController
@RequestMapping("/advices")
public class AdviceController {
  @GetMapping("/str")
  public String str() {
    return "success" ;
  }
  @GetMapping("/{id}")
  public User body(@PathVariable("id") Long id) {
    return new User(id, "張三 - " + new Random().nextInt(1000)) ;
  }
}

首先,測試接口/advices/{id}

圖片圖片

處理了最終的返回結果。

繼續測試/advices/str

圖片圖片

程序出錯了

控制臺輸出

java.lang.ClassCastException: class com.pack.common.dto.R cannot be cast to class java.lang.String (com.pack.common.dto.R is in unnamed module of loader 'app'; java.lang.String is in module java.base of loader 'bootstrap')
  at org.springframework.http.converter.StringHttpMessageConverter.addDefaultHeaders(StringHttpMessageConverter.java:44) ~[spring-web-5.3.27.jar:5.3.27]
  at org.springframework.http.converter.AbstractHttpMessageConverter.write(AbstractHttpMessageConverter.java:211) ~[spring-web-5.3.27.jar:5.3.27]

出現ClassCastException錯誤,是由于Controller接口返回值是String,那么匹配到的HttpMessageConverter是StringHttpMessageConverter處理,而該轉換器的調用是在ResponseBodyAdvice之后執行,這時候的字符串已經被轉換成了R對象,所以最后在write時就出現了類型轉換錯誤。通過如下方式處理

public Object beforeBodyWrite(Object body, 
      MethodParameter returnType, 
      MediaType selectedContentType,
      Class<? extends HttpMessageConverter<?>> selectedConverterType, ServerHttpRequest request,
      ServerHttpResponse response) {
  if (body instanceof String) {
    try {
      return this.objectMapper.writeValueAsString(R.success(body)) ;
    } catch (JsonProcessingException e) {
      e.printStackTrace();
    }
  }
  
  return R.success(body) ;
}

圖片

針對返回值是String類型的正常了。

通過自定義注解排除那些不需要處理的接口

@Target({ElementType.METHOD, ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
public @interface NoR {
}

修改PackResponseBodyAdvice#supports方法,添加NoR注解的判斷

public boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType) {
  // 方法上或者是類上沒有NoR注解
  return (!returnType.hasMethodAnnotation(NoR.class) 
            || AnnotatedElementUtils.hasAnnotation(returnType.getContainingClass(), NoR.class)) 
         && !returnType.getParameterType().equals(R.class)  ;
}

這樣就可以控制具體哪些方法不進行處理了。

通過自定義ResponseBodyAdvice,我們可以實現接口統一返回值的處理,從而提高了接口的可讀性、擴展性和錯誤處理能力。同時,這也有助于保持代碼的清晰和規范。通過學習和實踐,我們可以更好地利用SpringMVC相應的功能,開發出更優秀的應用程序。

責任編輯:武曉燕 來源: Spring全家桶實戰案例源碼
相關推薦

2025-02-13 00:34:22

Spring對象系統

2019-08-22 14:02:00

Spring BootRestful APIJava

2024-08-09 08:25:32

Spring流程注解

2020-05-26 13:48:05

后端框架異常

2018-04-27 14:18:01

2009-06-22 10:41:34

Spring.AOP

2022-08-03 08:41:30

客戶端操作并發請求

2021-06-17 09:32:39

重復請求并發請求Java

2020-11-10 10:21:31

架構try...catch代碼

2024-08-01 11:41:54

C#OneOf返回值

2022-11-09 07:42:51

Python編程函數

2009-12-07 11:11:41

WCF返回值

2024-03-14 09:19:49

2022-05-30 08:03:06

后端參數校驗異常處理

2024-10-28 08:32:22

統一接口響應SpringBoot響應框架

2011-04-20 11:04:23

LinuxHTTP 302

2009-08-27 09:57:24

Power7處理器

2012-06-01 15:39:46

休眠狀態墓碑狀態

2023-11-28 14:32:04

2011-04-25 13:06:57

iPad2蘋果A5處理器
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区国产精品 | 亚洲av一级毛片 | 伊人亚洲 | 精品欧美一区二区在线观看视频 | 日韩免费毛片 | 一级看片免费视频 | 一区二区三区精品视频 | 成人在线观看网址 | 99久久精品国产麻豆演员表 | 亚洲视频中文字幕 | 欧美aⅴ在线观看 | 亚洲日韩中文字幕一区 | 日本涩涩视频 | 日韩精品一区二区三区久久 | 欧美日韩国产一区二区三区 | 欧美国产精品一区二区三区 | 狠狠操网站| 欧美日韩黄色一级片 | 国产成人自拍一区 | 国产精品精品视频一区二区三区 | 自拍偷拍精品 | 91在线视频免费观看 | 国产资源在线观看 | 国产亚洲精品精品国产亚洲综合 | 亚洲伦理自拍 | 亚洲精品性视频 | 亚洲高清视频一区 | 久久天天 | 久久精品91久久久久久再现 | 国产999精品久久久久久 | 我爱操 | 成人在线一区二区三区 | 在线国产一区 | 成年男女免费视频网站 | 人人草天天草 | 亚洲免费视频网站 | 狠狠综合久久av一区二区老牛 | 国产精品免费大片 | 欧美成年网站 | 中文字幕在线播放第一页 | 国产精品入口麻豆www |