精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

久久精品视频2| 精品人妻在线视频| 午夜视频在线免费观看| 国内精品伊人久久久久av影院| 日韩在线观看免费全| 国模大尺度视频| 性国裸体高清亚洲| 国产精品久久久久天堂| 成人18视频| 天天射天天干天天| 国产尤物精品| 一二美女精品欧洲| 免费不卡的av| 欧美黄页免费| 午夜视频在线观看一区二区| 视频在线一区二区三区| 午夜精品久久久久久久96蜜桃 | 久久精品波多野结衣| 国产suv精品一区| 欧美日韩午夜影院| 黄色一级视频片| 老司机精品视频在线观看6| 99re成人精品视频| 亚洲自拍小视频免费观看| 69国产精品视频免费观看| 91精品精品| 一区二区在线视频播放| 88av在线播放| 天堂精品在线视频| 欧美蜜桃一区二区三区| 成年网站在线免费观看| av电影院在线看| ...中文天堂在线一区| 日本一区视频在线观看| 天天操天天操天天| 国产suv一区二区三区88区| 国产欧美va欧美va香蕉在| 国产91精品一区| 99在线精品视频在线观看| 色综合久久精品亚洲国产| 亚洲女人毛茸茸高潮| 国产麻豆精品久久| 国产视频精品一区二区三区| 视频免费在线观看| gogo久久日韩裸体艺术| 欧美成人午夜电影| 亚洲精品一二三四| 538任你躁精品视频网免费| 欧美一区二区三区人| 97超碰人人爽| 久久99久久久精品欧美| 欧美最猛黑人xxxxx猛交| aaa毛片在线观看| 欧美片第1页| 欧美特黄级在线| 亚洲国产精品久久久久婷蜜芽| www.九色在线| 欧美日韩国产一区二区三区| 精品视频免费在线播放| 岛国av在线网站| 无码av免费一区二区三区试看| 男人天堂av片| 免费h在线看| 亚洲18色成人| 久久精品.com| www.久久| 欧美一区二区三区四区久久| 国产精品日日摸夜夜爽| 国产精品极品| 亚洲欧洲激情在线| 91麻豆制片厂| 中文一区一区三区免费在线观看| 欧美成人中文字幕| 国产在线观看成人| 亚洲欧美成人| 国产精品久久一区主播| 国产一区二区三区四区视频| 国产电影一区二区三区| 国产91精品入口17c| 亚洲av成人精品一区二区三区在线播放 | 手机看片一区二区| 久久久99久久| 久久免费看毛片| aa在线视频| 午夜不卡av在线| 国产天堂在线播放| 欧美1区2区3| 日韩电影在线观看永久视频免费网站| aaaaa级少妇高潮大片免费看| 成人av动漫在线观看| 免费91麻豆精品国产自产在线观看| 激情小说中文字幕| 久久久噜噜噜| 亚洲aⅴ男人的天堂在线观看| 欧洲精品久久一区二区| 欧美国产欧美综合| 日本男女交配视频| 香蕉成人影院| 亚洲成人精品视频在线观看| av电影在线不卡| 国精品一区二区三区| 国产成人中文字幕| 国产视频第一页| 久久老女人爱爱| 欧美做受777cos| 日韩在线短视频| 日韩精品一区二区三区视频播放| av男人的天堂av| 欧美精品首页| 国产日本欧美一区| 天堂中文资源在线观看| 亚洲女同一区二区| 国产一区二区视频免费在线观看| 欧美高清hd| 在线观看国产精品日韩av| 国产一级在线播放| 国产一区二区三区久久悠悠色av | 中文字幕第17页| 色婷婷综合久久久久久| 欧美成人激情视频| 中国精品一区二区| 91啪亚洲精品| 超碰成人免费在线| 国产精品18| xxx一区二区| 日韩电影在线观看一区二区| av电影在线观看完整版一区二区| 国产精品jizz在线观看老狼| 久久野战av| 国产视频欧美视频| 国产在线拍揄自揄拍| 国产黄色成人av| 国产精品一区在线免费观看| 午夜精品久久久久久毛片| 亚洲天堂网在线观看| 国产成人在线免费视频| a级高清视频欧美日韩| 波多野结衣 作品| 二区三区精品| 久久亚洲影音av资源网 | 国产极品国产极品| 捆绑调教一区二区三区| 欧洲久久久久久| 香蕉久久免费电影| 亚洲欧美国产视频| 精品国产xxx| 久久久精品tv| 91色国产在线| 日本一区二区免费高清| 国产精品啪视频| 免费超碰在线| 91精品国产美女浴室洗澡无遮挡| 日本黄色免费片| 国产一区欧美二区| 少妇久久久久久被弄到高潮| 玖玖精品一区| 久久久在线视频| 午夜黄色小视频| 999久久久精品国产| 白嫩白嫩国产精品| 日韩中字在线| 亚洲国产日本| 91精品在线观看国产| 久久久亚洲人| 丝袜美腿亚洲一区| 国产婷婷精品av在线| 色av综合在线| 中文字幕一区二区三区电影| 国内精品伊人久久| 精品这里只有精品| 深夜成人影院| 最近2019中文免费高清视频观看www99| 国产suv精品一区二区33| 久久精品视频在线看| 精品日韩久久久| 国产精品成久久久久| av色综合网| 中国字幕a在线看韩国电影| 亚洲欧美中文另类| 91在线公开视频| 亚洲影院在线观看| 免费的av网站| 毛片av一区二区| 高清无码一区二区在线观看吞精| 精品福利网址导航| 国产精品成人va在线观看| 日本中文字幕在线2020| 日韩欧美成人一区| 国产精品xxxxxx| 夜夜亚洲天天久久| 少妇光屁股影院| 精品一区二区免费视频| 极品美女扒开粉嫩小泬| 国内精品视频在线观看| 97影院在线午夜| 欧美亚洲韩国| 欧美精品九九久久| se在线电影| 亚洲精品在线三区| 在线观看视频二区| 午夜精品影院在线观看| 99久久99久久精品免费| 成人免费三级在线| 午夜免费看毛片| 免费精品视频| 99热这里只有精品免费| 精品黄色一级片| 风间由美久久久| 日韩欧美三区| 国产97在线|亚洲| 国产蜜臀av在线播放| 影音先锋日韩有码| 图片区 小说区 区 亚洲五月| 欧美久久久一区| www五月天com| 亚洲一区二区三区在线播放| 一本一本久久a久久| 久久免费的精品国产v∧| 欧美午夜精品一区二区| 另类小说一区二区三区| 超碰97人人射妻| 亚洲一级高清| 五月天激情图片| 99免费精品| 午夜精品一区二区三区四区| 久久资源综合| 不卡一区二区三区视频| 国产一区二区三区视频在线| 国产精品视频在线观看| 香蕉久久免费电影| 欧美一级大片在线免费观看| 青草在线视频在线观看| 欧美精品在线极品| 久久日韩视频| 久久久国产一区二区| aiai在线| 尤物tv国产一区| 成人综合影院| 亚洲网址你懂得| 免费国产在线观看| 亚洲欧美另类国产| 色猫av在线| 日韩精品中文在线观看| 天天摸夜夜添狠狠添婷婷| 亚洲精品在线电影| 欧美熟女一区二区| 亚洲第一福利网站| 四虎永久在线观看| 亚洲精品国产精品乱码不99按摩| 黄色av网址在线| 精品国产伦一区二区三区观看方式 | 亚洲在线视频一区| 久久国产精品二区| 亚洲午夜精品在线| 亚洲欧美在线视频免费| 亚洲成年人影院| 圆产精品久久久久久久久久久| 亚洲成av人片一区二区| 日韩女同强女同hd| 疯狂做受xxxx高潮欧美日本| 黄色一级片免费在线观看| 一本大道久久a久久综合婷婷| 日韩美一区二区| 日本丰满少妇一区二区三区| 中文字幕+乱码+中文| 欧美日韩高清在线| 国产丰满美女做爰| 亚洲精品国产精品国自产在线 | 欧美理伦片在线播放| 久久综合色一本| 欧美亚洲国产精品久久| youjizz.com亚洲| 欧美日韩亚洲一区二区三区在线| 久久国产精品网| 视频一区欧美日韩| 97婷婷大伊香蕉精品视频| www.国产一区二区| 欧洲生活片亚洲生活在线观看| 亚洲天堂网视频| 日韩一二三区视频| 欧美午夜黄色| 日韩中文字幕国产| 欧美xxxx做受欧美88bbw| 4p变态网欧美系列| 成人精品一区二区三区电影| 91大片在线观看| 婷婷成人在线| 亚洲一区尤物| 亚洲精品社区| 午夜免费福利在线| 波多野结衣91| av在线播放中文字幕| 一区二区三区av电影| 久青草视频在线观看| 色综合久久久久久久久久久| 国产精品国产三级国产普通话对白| 精品福利一区二区三区免费视频| 久久久久国产精品嫩草影院| 久久久999成人| 午夜欧美激情| 97人摸人人澡人人人超一碰| 久久av导航| 日韩精品一区二区免费| 天堂va蜜桃一区二区三区| 亚洲少妇一区二区| 欧美经典一区二区| 免费观看一级视频| 欧美日韩一级二级| 手机在线不卡av| 欧美高清视频在线| 999国产精品亚洲77777| 九九九九九精品| 欧美一区亚洲| 精品日韩久久久| 久久综合成人精品亚洲另类欧美 | 亚洲 欧美 精品| 欧美另类高清videos| 电影一区二区| 久久艳妇乳肉豪妇荡乳av| 中文字幕一区二区三三 | 国产成人综合在线观看| 韩国女同性做爰三级| 香蕉久久一区二区不卡无毒影院| 国产精品毛片一区二区在线看舒淇| 亚洲欧美自拍一区| 丁香花在线影院| 亚洲伊人第一页| 99国产**精品****| 国产嫩草在线观看| 久久久久国产精品免费免费搜索| 日本少妇xxxx动漫| 欧美一级午夜免费电影| 蜜桃av在线免费观看| 国产精品久久久久久久久久久久久久| 亚洲成aⅴ人片久久青草影院| heyzo亚洲| 北条麻妃一区二区三区| 欧美日韩成人免费观看| 日韩一区二区三区在线| 黄色精品在线观看| 成人a在线视频| 国产精品精品国产一区二区| 91亚洲免费视频| 欧美高清一级片在线观看| 国产精品第六页| 国产一区二区三区18| 成人午夜视屏| 日本公妇乱淫免费视频一区三区| 在线综合视频| 一本色道久久综合亚洲精品图片| 五月婷婷激情综合| 日韩一级在线播放| 97色在线播放视频| 亚洲午夜久久| 熟妇人妻无乱码中文字幕真矢织江 | 91久久视频| 日韩无码精品一区二区| 欧美日韩国产丝袜美女| 韩国中文字幕2020精品| 国产精品一香蕉国产线看观看 | 中文字幕av影视| 久久精品99国产精品酒店日本| 四虎成人精品一区二区免费网站| 一级二级三级欧美| 久久超碰97人人做人人爱| 中日韩一级黄色片| 精品免费一区二区三区| h片在线观看视频免费| 久久久久久a亚洲欧洲aⅴ| 视频一区中文字幕国产| 中文字幕乱码av| 精品免费国产一区二区三区四区| 岛国av在线网站| 香蕉久久夜色| 国产精品一区二区在线观看不卡| 国产第100页| 亚洲欧美综合精品久久成人| 青青青国产精品| 隔壁人妻偷人bd中字| 久久免费看少妇高潮| 91影院在线播放| 久久久免费观看视频| 亚瑟一区二区三区四区| 视色视频在线观看| 亚洲一区二区欧美激情| 九色在线视频| 亚洲a级在线观看| 国产深夜精品| 中文字幕求饶的少妇| 亚洲大胆人体在线| 天堂久久一区| 亚洲熟妇国产熟妇肥婆| 国产精品久久久久久久裸模 | 亚洲精品资源美女情侣酒店| 国模私拍国内精品国内av| 800av在线免费观看| 亚洲国产高清aⅴ视频| 亚洲国产精品久久人人爱潘金莲 | 黄色av网站免费| 色综合视频网站|