shenyu怎麼處理sign鑒權前置到網關
前言
shenyu以前叫soul網關,我比較早關註它的,直到前不久看到它們創始人發的朋友圈,才知道現在已經是apache頂級項目瞭,666
今天我點瞭下shenyu issue裡頭逛逛,發現瞭一個老哥說能否做到對簽名插件的擴展,然後我就去看瞭shenyu裡頭怎麼實現驗簽的
github.com/apache/shen…
加瞭他們創始人微信挺久瞭,也關註shenyu網關一段時間,因為本身在架構組也會接觸網關內容
shenyu網關
shenyu跟其他網關一樣,都是通過責任鏈的方式,這樣可以靈活進行擴展,也能做到每個處理類都難處理到。
我目前項目也有鑒權功能,也看看別人是怎麼實現的
鑒權sign
首先肯定是找到對應的模塊,shenyu-plugin-sign,SignPlugin 就是網關處理鏈條中的一環。
@Bean public ShenyuPlugin signPlugin(final SignService signService) { return new SignPlugin(signService); }
就是你在項目裡頭註入哪個SignService實現類,它會塞到這插件裡頭來。
它會去判斷規則是否存在,什麼規則?就是驗證簽名的時候那些配置,比如說多久超時,哪些url要通過sign驗簽。
但是這裡也暴露瞭一個問題,過度依賴配置,如果做到高可用,可以做一層backup備份,如果沒有配置,或者配置讀不到的情況下,讀取上次配置的內容。
DefaultSignService
這裡有個比較好的東西,就是會將一些內容封裝到上下文裡頭,比如說a節點,處理瞭一個東西,還要set一個特殊的key到header裡面,然後讓後面的去拿,這就很不方便瞭,如果是放在上下文的話,這就統一處理。
驗簽邏輯開始,首先是對時間做驗證,然後再是算法驗。
這裡我要直呼一聲好傢夥,exchange.getRequest().getQueryParams()直接拿到請求的參數,如果你在服務裡面實現那得累死你,區分post、get請求,需要特殊處理。
buildParamsMap(shenyuContext, requestBody)
這個map裡頭有啥?加瞭時間戳、url、版本號,請求參數(去除sign)
DigestUtils.md5DigestAsHex(sign.getBytes()).toUpperCase()
這裡是sign簽名算法
總結
到這裡,shenyu的sign插件邏輯就差不多瞭,直呼好傢夥,跟我現在項目裡頭驗簽邏輯一毛一樣,隻是簽名算法有所不同。但是這裡面還是有些能優化的點,比如說過度依賴shenyu現有的配置內容,需要做到網關點高可用~
shenyu這裡跟其他配置中心也有所不一樣,采用map來接收配置內容,我們看nacos、apolla這些框架是刷新到eventment環境變量裡頭去。
以上就是shenyu怎麼處理sign鑒權前置到網關的詳細內容,更多關於shenyu處理sign鑒權前置網關的資料請關註WalkonNet其它相關文章!
推薦閱讀:
- Java雙重MD5加密實現安全登錄
- Gateway網關自定義攔截器的不可重復讀取數據問題
- Docker運行Nacos容器自動退出問題的解決方法
- 網關Gateway過濾器的使用詳解
- 使用Feign消費服務時POST/GET請求方式詳解