精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

SpringCloud Alibaba微服務實戰之隱私接口禁止外部訪問

開發 架構
今天我們要反其道而行之,介紹在SpringCloud體系中如何防止內部隱私接口被網關調用。

 [[414726]]

本文轉載自微信公眾號「JAVA日知錄」,作者飄渺Jam。轉載本文請聯系JAVA日知錄公眾號。

大家好,我是飄渺!

在SpringCloud實戰系列文章中曾經介紹過在SpringCloud體系下如何防止前端請求繞過網關直接到達后端微服務,今天我們要反其道而行之,介紹在SpringCloud體系中如何防止內部隱私接口被網關調用。

看到這里可能有的同學會有點暈,怎么還有這種業務場景呢,別急,咱們先回顧一下我們的業務場景。

業務場景

客戶端通過網關調用OrderService服務獲取數據,OrderService通過Feign調用AccountService服務,而當AccountService提供對應的Feign接口后,客戶端是可以通過網關直接調用AccountService接口的。

現在假設AccountService提供的接口包含了部分隱私數據,只允許內部調用協助OrderService進行業務邏輯處理,不允許客戶端直接獲取,此時咱們需要怎么做?

業務實戰

我們先通過代碼將原始的流程實現出來,即通過網關調用OrderService的OrderController,然后在OrderController中通過Feign調用AccountService的AccountController,為了便于閱讀,文章中刪除了部分無用代碼。

模擬實現

入口 OrderController

  1. public class OrderController { 
  2.     private final OrderService orderService; 
  3.     private final AccountClient accountClient; 
  4.  
  5.  
  6.     @GetMapping("/order/{orderNo}"
  7.     public ResultData<OrderDTO> getById(@PathVariable("orderNo") String orderNo){ 
  8.         OrderDTO orderDTO = orderService.selectByNo(orderNo); 
  9.         ResultData<String> secretValue = accountClient.getSecretValue(); 
  10.         log.info(secretValue); 
  11.         return ResultData.success(orderDTO); 
  12.     } 

在OrderController中通過AccountClient調用AccountService

  1. ResultData<String> secretValue = accountClient.getSecretValue(); 

Feign接口

  1. public interface AccountApi { 
  2.   ... 
  3.     @GetMapping("/account/getSecretValue"
  4.     ResultData<String> getSecretValue(); 
  5.   ... 

AccountController實現

  1. @RestController 
  2. @Log4j2 
  3. @Api(tags = "account接口"
  4. @RequiredArgsConstructor(onConstructor = @__(@Autowired)) 
  5. public class AccountController implements AccountApi { 
  6.  
  7.     /** 
  8.      * 隱私接口,禁止通過網關訪問 
  9.      */ 
  10.     @Override 
  11.     @GetMapping("/account/getSecretValue"
  12.     public ResultData<String> getSecretValue() { 
  13.         return ResultData.success("隱私接口,禁止通過網關訪問"); 
  14.     } 
  15.      

正如我們前面所說,一旦提供了Feign接口,在默認情況下我們可以直接通過網關訪問getSecretValue()方法,那怎么確保這個方法不讓外部調用呢?

解決方案

網上現在大部分的解決辦法是基于黑名單機制,即將這些接口放入“黑名單”中存儲起來,在網關啟動時讀取黑名單配置,然后校驗是否在黑名單中。

這種辦法確實也可以,但是總感覺不夠靈活,而且實現也比較繁瑣,這里就不展開了。

我們今天介紹的是利用訪問路徑來實現,非常簡單輕便。

實現原理

我們需要借助接口路徑規范來實現,即給接口指定訪問路徑時采用這樣的格式 : /訪問控制/接口。

訪問控制可以有以下幾個規則(參考JAVA包規范),可根據業務需要進行擴展。

  1. pb - public 所有請求均可訪問 
  2.  
  3. pt - protected 需要進行token認證通過后方可訪問 
  4.  
  5. pv - private 無法通過網關訪問,只能微服務內部調用 
  6.  
  7. df - default 網關請求token認證,并且請求參數和返回結果進行加解密 
  8.  
  9. ... 

有了這套接口規范以后,我們就可以靈活控制接口訪問權限,然后在網關對接口路徑進行校驗,如果命中對應的訪問控制規則就進行對應的邏輯處理。

代碼實戰

既然知道了實現原理,那寫代碼就很簡單了。

修改接口訪問路徑,遵循接口路徑規范

  1. public interface AccountApi { 
  2.     @GetMapping("/pv/account/getSecretValue"
  3.     ResultData<String> getSecretValue(); 

修改feign的訪問路徑。

  1. @RestController 
  2. @Log4j2 
  3. @Api(tags = "account接口"
  4. @RequiredArgsConstructor(onConstructor = @__(@Autowired)) 
  5. public class AccountController implements AccountApi { 
  6.  
  7.     /** 
  8.      * 隱私接口,禁止通過網關訪問 
  9.      */ 
  10.     @Override 
  11.     @GetMapping("/pv/account/getSecretValue"
  12.     public ResultData<String> getSecretValue() { 
  13.         return ResultData.success("隱私接口,禁止通過網關訪問"); 
  14.     } 
  15.      

修改接口實現類的訪問路徑,這里需要與Feign的路徑保持一致。

網關自定義攔截器進行接口校驗

  1. @Component 
  2. @Order(0) 
  3. @Slf4j 
  4. public class GatewayRequestFilter implements GlobalFilter { 
  5.  
  6.     @Override 
  7.     public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { 
  8.         //獲取請求路徑 
  9.         String rawPath = exchange.getRequest().getURI().getRawPath(); 
  10.  
  11.         if(isPv(rawPath)){ 
  12.             throw new HttpServerErrorException(HttpStatus.FORBIDDEN,"can't access private API"); 
  13.         } 
  14.         return chain.filter(newExchange); 
  15.     } 
  16.  
  17.     /** 
  18.      * 判斷是否內部私有方法 
  19.      * @param requestURI 請求路徑 
  20.      * @return boolean 
  21.      */ 
  22.     private boolean isPv(String requestURI) { 
  23.         return isAccess(requestURI,"/pv"); 
  24.     } 
  25.  
  26.     /** 
  27.      * 網關訪問控制校驗 
  28.      */ 
  29.     private boolean isAccess(String requestURI, String access) { 
  30.         //后端標準請求路徑為 /訪問控制/請求路徑 
  31.         int index = requestURI.indexOf(access); 
  32.         return index >= 0 && StringUtils.countOccurrencesOf(requestURI.substring(0,index),"/") < 1; 
  33.     } 
  34.  

通過上面簡單兩步我們就能實現本文提出的問題了,接下來我們測試一下。

測試

直接訪問后端服務,提示無法訪問。

通過OrderService訪問后端服務正常訪問。

小結

讓內部隱私接口不被外部訪問,我相信做微服務開發的同學基本都會遇到。本文中提供的解決方案代碼量很少而且接口路徑規范可以根據自己的業務規則進行修改擴展,推薦大家使用。其實代碼不是關鍵,關鍵在于要讓團隊共同遵守這個接口規范,思想比實現更重要。

 

責任編輯:武曉燕 來源: JAVA日知錄
相關推薦

2021-01-28 10:10:51

微服務后端SpringCloud

2021-05-14 09:15:32

SpringCloud微服務日志

2021-03-09 09:33:42

網關授權微服務

2021-04-22 09:31:58

服務器微服務配置

2021-06-09 09:42:50

SpringCloud微服務灰度發布

2022-04-09 14:45:02

微服務常見概念Spring

2021-03-26 06:01:45

日志MongoDB存儲

2016-08-25 21:12:31

微服務架構發布

2016-08-25 20:55:19

微服務架構發布

2022-04-27 08:23:34

微服務負載均衡

2021-02-04 09:18:20

服務器認證自定義

2025-03-13 00:55:00

微服務架構系統

2023-02-07 07:43:27

微服務應用框架

2017-09-05 14:05:11

微服務spring clou路由

2025-04-17 02:00:00

2025-03-07 08:57:46

HTTP客戶端框架

2024-03-06 08:36:36

2021-05-31 11:22:24

微服務開發框架

2022-06-24 07:08:24

OHOS自定義服務

2022-05-29 21:38:11

限流熔斷流量
點贊
收藏

51CTO技術棧公眾號

国产aⅴ精品一区二区四区| 裸体xxxx视频在线| 国产精品videossex久久发布| 欧美一区二区人人喊爽| 草草视频在线免费观看| 国产小视频在线播放| 国产麻豆精品视频| 日本免费在线精品| 欧美激情一区二区视频| 久久av网址| 日韩一级高清毛片| 成人黄色一区二区| 国产精品国精产品一二| 国产精品麻豆99久久久久久| 国产精品裸体一区二区三区| 久久久久久无码精品大片| 欧美黄色aaaa| 自拍偷拍亚洲在线| 97人妻精品一区二区三区免| 亚洲爽爆av| 色婷婷国产精品综合在线观看| 黑人巨大国产9丨视频| 青青青免费视频在线2| 国产一区二区美女| 国产精品久久久久久久久久久久久 | 成人在线一区二区三区| 国产精品视频久久久| 日韩欧美国产亚洲| 欧美日韩国产高清| www.日韩av.com| 先锋影音av在线| 亚洲精品推荐| 亚洲国产福利在线| 国产一级二级av| 91精品国产一区二区在线观看| 欧美体内谢she精2性欧美| 欧美乱做爰xxxⅹ久久久| 日韩黄色影院| 国产精品视频观看| 日本精品一区二区| 裸体xxxx视频在线| 久久男人中文字幕资源站| 国产欧美日本在线| www.国产欧美| 国产福利一区在线| 91亚色免费| 国产乱码久久久久| 久久国产精品72免费观看| 国产激情综合五月久久| 国产69精品久久久久久久久久| 亚洲小说欧美另类婷婷| 久久91亚洲精品中文字幕奶水 | 日韩中文字幕综合| 国产成人精品影视| 999在线免费观看视频| 国产男男gay网站| 精品一区二区久久久| 国产欧美日韩高清| 国产精品区在线观看| 久久99精品国产.久久久久久| 国产欧美 在线欧美| 中文字幕你懂的| 麻豆国产精品一区二区三区| 成人高h视频在线| 国产视频在线免费观看| 国产东北露脸精品视频| 国产精品theporn88| 成人免费一级视频| 99久精品国产| 欧美中日韩一区二区三区| 国模精品一区二区| 国产精品久久久久久久裸模| 2025韩国大尺度电影| 污片在线免费观看| 都市激情亚洲色图| 性刺激的欧美三级视频| 伊人久久一区| 欧美zozozo| 欧美图片一区二区| 久久麻豆精品| 欧美美最猛性xxxxxx| 91浏览器在线观看| 麻豆精品一区二区av白丝在线| 成人字幕网zmw| 蜜桃av噜噜一区二区三区麻豆| 99久久99久久精品免费看蜜桃| 日韩av免费电影| av在线free| 欧美日韩国产综合新一区| 国产三级三级三级看三级| 91麻豆精品| 日韩av网站电影| 99国产精品无码| 韩日成人在线| 国产精品久久77777| 成人高潮片免费视频| 26uuu精品一区二区在线观看| 亚洲精品一区二区三区av| 午夜伦理大片视频在线观看| 日韩欧美在线网址| 日本亚洲一区二区三区| 久久91麻豆精品一区| 欧美成人精品在线播放| 亚洲GV成人无码久久精品| 国产另类ts人妖一区二区| 极品校花啪啪激情久久| 秋霞成人影院| 日韩欧美国产一区二区| 69久久精品无码一区二区| 亚洲aa在线| 九九热这里只有在线精品视| 中文字幕在线天堂| 成人国产电影网| 五月天色婷婷综合| 三级成人在线| 亚洲高清久久网| 希岛爱理中文字幕| 美美哒免费高清在线观看视频一区二区| 成人免费视频网站入口| 在线播放麻豆| 色婷婷久久99综合精品jk白丝| 在线播放国产视频| 色欧美自拍视频| 国产成人精品电影久久久| 黑人操亚洲女人| 亚洲免费在线观看| 污视频网站观看| 国产成人精品一区二区免费看京 | 老司机午夜网站| 成人国产一区| 亚洲人成电影网| 日本va欧美va国产激情| 成人免费视频一区| 女人床在线观看| 中文成人在线| 日韩一区二区欧美| 久久久999久久久| 久久久久亚洲蜜桃| 日韩精品视频久久| 日韩欧美中文字幕电影| 性欧美xxxx| 人妻精品一区二区三区| 亚洲国产一区视频| 麻豆av免费看| 亚洲第一黄网| 国产伦精品一区二区三区四区视频 | 91theporn国产在线观看| 中文字幕精品综合| 天天操,天天操| 久久美女视频| 亚洲综合中文字幕68页| av电影高清在线观看| 日韩限制级电影在线观看| 手机在线免费看毛片| 国产精品自拍三区| 妞干网视频在线观看| 国产精品久久久久久久久久白浆| 久久青草福利网站| 少妇高潮一区二区三区69| 亚洲成人综合视频| theav精尽人亡av| 蘑菇福利视频一区播放| 欧美少妇一区| 黑人一区二区三区| 欧美精品一区二区三区国产精品| 亚洲av永久无码国产精品久久| 亚洲午夜精品网| 亚洲国产综合视频| 日韩成人一级大片| 中国人体摄影一区二区三区| 精品一区二区三区免费看| 欧美国产日韩视频| 爽爽视频在线观看| 欧美日韩精品欧美日韩精品一综合 | 成人精品动漫一区二区三区| 68精品国产免费久久久久久婷婷| 日本亚洲一区| 欧美日韩国产另类一区| 免费网站观看www在线观| 不卡在线观看av| 欧在线一二三四区| 亚洲大全视频| 精品一区二区三区日本| 成人国产网站| 久久久亚洲影院你懂的| 国产区视频在线| 91精品国产欧美日韩| 日韩熟女精品一区二区三区| 欧美激情在线看| 免费看91视频| 日韩不卡免费视频| 国产片侵犯亲女视频播放| 亚洲另类春色校园小说| 91亚洲精品视频| 深夜在线视频| 欧美成人黄色小视频| 亚洲色大成网站www| 欧美精品久久99| 免费av网站在线| 一区二区三区四区在线免费观看 | 国产丝袜在线视频| 色综合色综合色综合 | 成人精品一区二区三区校园激情| 欧美日本在线一区| 六月丁香在线视频| 亚洲精品免费视频| 国产午夜福利一区| 99精品一区二区三区| 午夜xxxxx| 日本最新不卡在线| 国产精品网站免费| 永久91嫩草亚洲精品人人| 日本一区高清在线视频| 加勒比色综合久久久久久久久| 国产日韩欧美视频在线| 国产精品迅雷| 国a精品视频大全| 成人影院在线看| 中文字幕精品av| 青青草av免费在线观看| 亚洲第一免费播放区| 国产精品一区二区av白丝下载| 91国偷自产一区二区使用方法| 日本中文字幕免费观看| 亚洲精品成人在线| 韩国一级黄色录像| 国产精品女上位| 久久久久无码精品国产sm果冻| 99热这里都是精品| 亚洲免费观看在线| 国产成人自拍在线| 一级黄色片在线免费观看| 毛片av中文字幕一区二区| 日韩中文字幕免费在线| 亚洲专区在线| 日韩中文字幕在线视频观看| 亚洲日产国产精品| 亚洲熟妇无码一区二区三区导航| 亚洲一区二区日韩| 一级特黄妇女高潮| 香蕉综合视频| 欧美三级午夜理伦三级老人| 天天做天天爱天天综合网| 最新欧美日韩亚洲| 亚洲精品网址| 成人手机在线播放| 欧美激情麻豆| 国产av熟女一区二区三区| 欧美私人啪啪vps| 日本熟妇人妻xxxx| aa国产精品| 91九色在线观看视频| 国产农村妇女精品一区二区| 欧美亚洲另类色图| 久久精品人人| 一路向西2在线观看| 久久av老司机精品网站导航| 中文字幕1234区| 国产河南妇女毛片精品久久久| 亚洲视频在线不卡| 国产91在线看| 无码人妻aⅴ一区二区三区 | 开心激情五月网| 亚洲色图视频网站| 久久综合久久鬼| 欧美视频在线免费| 影音先锋国产在线| 欧美一区二区国产| 日韩在线观看视频一区| 精品亚洲精品福利线在观看| 高清日韩av电影| 久久久精品在线| 2021中文字幕在线| 国产精品h片在线播放| 日韩五码电影| 国产激情一区二区三区在线观看| 秋霞在线一区| 亚洲国产午夜伦理片大全在线观看网站 | 中文字幕高清一区| 欧美日韩一级大片| 亚洲线精品一区二区三区| 区一区二在线观看| 这里只有精品免费| 人人妻人人澡人人爽人人欧美一区| 亚洲女人天堂av| 成人看av片| 欧美在线视频a| 精品国产亚洲一区二区在线观看| 国产一区喷水| 99re6这里只有精品| 亚洲人成无码网站久久99热国产| 日韩—二三区免费观看av| 91视频免费入口| 国产日本欧洲亚洲| 国产无码精品一区二区| 在线观看成人小视频| 黄片毛片在线看| 中文字幕亚洲精品| 不卡视频观看| 91丨九色丨国产在线| 中国av一区| 久久av综合网| 精东粉嫩av免费一区二区三区| 97香蕉碰碰人妻国产欧美| 亚洲视频综合在线| 一级做a爰片久久毛片| 日韩精品一区二区三区视频| 成人免费在线视频网| 97国产精品视频人人做人人爱| 欧洲美女精品免费观看视频| 精品一区二区三区视频日产| 午夜国产欧美理论在线播放 | 成人一区二区在线观看| youjizz亚洲女人| 欧美午夜美女看片| 黄色a在线观看| 美女福利精品视频| 精品久久在线| 日韩精品不卡| 久久av一区二区三区| 中文字幕视频观看| 亚洲精品视频观看| 国产又粗又长又大视频| 国产一区二区三区高清在线观看 | 国产欧美日韩丝袜精品一区| 羞羞色国产精品网站| 日韩亚洲欧美视频| 国产成人午夜99999| 欧美另类videoxo高潮| 在线观看中文字幕不卡| 久草视频在线看| 欧美在线www| 亚洲婷婷丁香| 成人观看免费完整观看| 91丝袜高跟美女视频| 国产尤物在线视频| 亚洲精品日韩丝袜精品| 中文字幕资源网在线观看免费| 精品久久久久久久一区二区蜜臀| 在线观看免费小视频| 亚洲成人精品一区| 欧美视频一二区| 国内精品久久久久影院优 | 久久精品99久久| 国产精品久久久久9999高清| 亚洲熟女一区二区| 欧美日韩国产一区二区| 男女网站在线观看| 国产成人精品av在线| 日韩av有码| 亚洲午夜精品一区| 亚洲精品伦理在线| 国产1区在线观看| 8090成年在线看片午夜| 男男gay无套免费视频欧美| 男女曰b免费视频| 亚洲国产电影在线观看| 国产又粗又猛又爽| 麻豆国产va免费精品高清在线| 中文字幕日韩高清在线| 日韩xxxx视频| 久久久亚洲综合| 亚洲性在线观看| 欧美猛男性生活免费| 三级精品视频| 一区二区三区视频在线观看免费| 国产精品每日更新在线播放网址 | 国产一区二区三区免费观看| 国产精品成人免费观看| 亚洲国产另类 国产精品国产免费| 性欧美xxx69hd高清| 一区二区不卡在线| 国产风韵犹存在线视精品| 成年人视频在线免费看| 色综合亚洲精品激情狠狠| 99亚洲乱人伦aⅴ精品| 无码aⅴ精品一区二区三区浪潮 | 国产情侣自拍小视频| 欧美激情视频在线| 亚洲区小说区| 亚洲一区二区三区四区精品| 红桃视频成人在线观看| 欧美人xxx| 精品中文字幕一区| 精品无码三级在线观看视频| 中日韩精品视频在线观看| 中文字幕在线观看亚洲| 国产精品视频3p| 天天色综合社区| 精品福利樱桃av导航| 男人天堂久久久| 蜜桃传媒视频麻豆一区| 国产综合久久久久久久久久久久| 制服.丝袜.亚洲.中文.综合懂色| 色av吧综合网| 无码日韩精品一区二区免费| 伊人精品视频在线观看| 色哟哟一区二区在线观看| 亚洲精品一线| 亚洲国产精品久久久久婷婷老年|