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

Spring MVC高級知識點:自定義請求匹配路徑

開發 前端
希望根據請求中header['x-token']的不同值調用不同的接口。接口請求地址相同,根據不同的header信息調用不同的執行方法。

[[417331]]

環境:springboot2.2.10.RELEASE

自定義請求匹配

希望根據請求中header['x-token']的不同值調用不同的接口。接口請求地址相同,根據不同的header信息調用不同的執行方法。

在SpringMVC中可以通過自定義

RequestMappingHandlerMapping#getCustomMethodCondition來實現此功能。

自定義請求匹配通過實現RequestCondition接口自定義規則

系統默認提供了以下RequestCondition實現

Spring MVC高級知識點自定義請求匹配路徑

自定義匹配條件

  1. public class CustomRequestCondition implements RequestCondition<CustomRequestCondition> { 
  2.      
  3.     private static final String X_TOKEN_NAME = "x-token" ; 
  4.  
  5.     private Method method ; 
  6.      
  7.     public CustomRequestCondition(Method method) { 
  8.         this.method = method ; 
  9.     } 
  10.      
  11.     // 當接口上有多個匹配規則時,進行合并操作 
  12.     @Override 
  13.     public CustomRequestCondition combine(CustomRequestCondition other) { 
  14.         return new CustomRequestCondition(other.method) ; 
  15.     } 
  16.  
  17.     // 核心方法:根據匹配的條件進行判斷是否匹配,如果匹配則返回當前的對象,不匹配則返回null 
  18.     @Override 
  19.     public CustomRequestCondition getMatchingCondition(HttpServletRequest request) { 
  20.         AKF akf = method.getAnnotation(AKF.class) ; 
  21.         return akf != null ? buildToken(request, akf) : null ; 
  22.     } 
  23.  
  24.     // 當有多個都滿足條件的時候,進行比較具體使用哪個 
  25.     @Override 
  26.     public int compareTo(CustomRequestCondition other, HttpServletRequest request) { 
  27.         return 0 ; 
  28.     } 
  29.      
  30.     // 判斷請求header中的信息與注解中配置的信息是否一致 
  31.     private CustomRequestCondition buildToken(HttpServletRequest request, AKF akf) { 
  32.         String xToken = request.getHeader(X_TOKEN_NAME) ; 
  33.         if (xToken == null || xToken.length() == 0) { 
  34.             return null ; 
  35.         } 
  36.         return xToken.equals(akf.value()) ? this : null ; 
  37.     } 
  38.  

自定義HandlerMapping

  1. public class CustomMethodConditionRequestHandlerMapping extends RequestMappingHandlerMapping { 
  2.     @Override 
  3.     protected RequestCondition<?> getCustomMethodCondition(Method method) { 
  4.         return new CustomRequestCondition(method) ; 
  5.     } 

配置自定義的HandlerMapping

  1. @Configuration 
  2. public class CustomEndpointConfig extends WebMvcConfigurationSupport { 
  3.      
  4.     @Override 
  5.     protected RequestMappingHandlerMapping createRequestMappingHandlerMapping() { 
  6.         return new CustomMethodConditionRequestHandlerMapping() ; 
  7.     } 
  8.      

注冊HandlerMapping我們也可以通過@Bean的方式,但是這種方式會使得你在定義多個相同接口地址的時候容器啟動就會報錯

而且@Bean的方式是向容器中注冊一個HandlerMapping對象;而通過上面的方式就是替換系統默認的

RequestMappingHandlerMapping對象。兩種方式是不一樣的,一個是增加一個HandlerMapping,一個是替換系統默認的。

測試接口

  1. @RestController 
  2. @RequestMapping("/conditions"
  3. public class CustomMethodConditionController { 
  4.      
  5.     @GetMapping("/index"
  6.     public Object index() { 
  7.         return "custom method condition success" ; 
  8.     } 
  9.      
  10.     @GetMapping("/index"
  11.     @AKF 
  12.     public Object x() { 
  13.         return "x method invoke" ; 
  14.     } 
  15.      
  16.     @GetMapping("/index"
  17.     @AKF("x1"
  18.     public Object x1() { 
  19.         return "x1 method invoke" ; 
  20.     } 
  21.      
  22.     @GetMapping("/index"
  23.     @AKF("x2"
  24.     public Object x2() { 
  25.         return "x2 method invoke" ; 
  26.     } 
  27.      

上面的接口地址完全相關,只是有些有@AKF注解,有些沒有。

如果通過@Bean注冊一個HandlerMapping后,多個請求路徑相同會報如下錯誤:

  1. Caused by: java.lang.IllegalStateException: Ambiguous mapping. Cannot map 'customMethodConditionController' method  
  2. com.pack.controller.CustomMethodConditionController#x() 
  3. to {GET /conditions/index}: There is already 'customMethodConditionController' bean method 
  4. com.pack.controller.CustomMethodConditionController#index() mapped. 
  5.     at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping$MappingRegistry.validateMethodMapping(AbstractHandlerMethodMapping.java:636) ~[spring-webmvc-5.2.9.RELEASE.jar:5.2.9.RELEASE] 
  6.     at org.springframework.web.servlet.handler.AbstractHandlerMethodMapping$MappingRegistry.register(AbstractHandlerMethodMapping.java:603) ~[spring-webmvc-5.2.9.RELEASE.jar:5.2.9.RELEASE] 

在以上的請求中如果請求中沒有攜帶x-token信息或者是value值不被匹配那么請求會是404。

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2023-12-04 07:27:54

SpringMVC方法

2016-05-30 17:31:34

Spring框架

2023-03-02 11:52:00

自定義自動配置

2022-11-10 07:53:54

Spring參數校驗

2024-01-24 11:59:44

Django自定義字段Python

2016-08-23 13:21:15

MVC路由視圖

2024-10-14 17:18:27

2021-04-13 08:25:12

測試開發Java注解Spring

2010-08-17 14:56:00

HCNE認證

2011-04-15 12:25:21

BGP路由

2025-01-07 14:10:46

SpringBoot開發Java

2009-11-24 15:11:21

ASP.NET MVC

2010-08-17 23:32:11

2023-12-22 15:32:20

2009-07-22 15:27:39

ASP.NET MVC自定義路由

2011-05-23 14:47:12

WordPress

2015-02-12 15:33:43

微信SDK

2011-03-17 09:45:01

Spring

2010-04-30 09:32:49

ASP.NET MVC

2015-02-12 15:38:26

微信SDK
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久久高清 | 日韩av福利在线观看 | 九九热精品视频在线观看 | 亚洲精品亚洲人成人网 | 久久中文免费视频 | 亚洲 欧美 日韩在线 | 久久久91 | 日本涩涩网 | 中国黄色在线视频 | 狠狠的干| 91在线电影| 成人欧美一区二区三区黑人孕妇 | av免费在线播放 | 欧美日韩精品 | 美女一级a毛片免费观看97 | 特黄色一级毛片 | 在线观看国产精品视频 | 伊人春色成人网 | 日本欧美国产在线 | 成人a免费 | 亚洲日韩中文字幕一区 | 夜久久 | 午夜小电影| 欧美精品v国产精品v日韩精品 | 国产精品欧美一区二区 | 国产区久久| 久久久久久91 | 日韩1区| 黄色大片网站 | 国产精品自产拍在线观看蜜 | 国产精品久久久久久久久动漫 | 国产欧美精品一区二区三区 | 久久精品国产一区二区电影 | 亚洲精品久久久蜜桃网站 | 久久日韩精品一区二区三区 | 91在线视频免费观看 | 日韩一级不卡 | 日韩在线一区二区三区 | 日本在线观看视频 | 欧美国产日韩成人 | 久久在线视频 |