shenyu怎么處理sign鑒權(quán)前置到網(wǎng)關(guān)
前言
shenyu以前叫soul網(wǎng)關(guān),我比較早關(guān)注它的,直到前不久看到它們創(chuàng)始人發(fā)的朋友圈,才知道現(xiàn)在已經(jīng)是apache頂級項目了,666
今天我點了下shenyu issue里頭逛逛,發(fā)現(xiàn)了一個老哥說能否做到對簽名插件的擴展,然后我就去看了shenyu里頭怎么實現(xiàn)驗簽的
加了他們創(chuàng)始人微信挺久了,也關(guān)注shenyu網(wǎng)關(guān)一段時間,因為本身在架構(gòu)組也會接觸網(wǎng)關(guān)內(nèi)容
shenyu網(wǎng)關(guān)
shenyu跟其他網(wǎng)關(guān)一樣,都是通過責(zé)任鏈的方式,這樣可以靈活進行擴展,也能做到每個處理類都難處理到。
我目前項目也有鑒權(quán)功能,也看看別人是怎么實現(xiàn)的
鑒權(quán)sign
首先肯定是找到對應(yīng)的模塊,shenyu-plugin-sign,SignPlugin 就是網(wǎng)關(guān)處理鏈條中的一環(huán)。
@Bean public ShenyuPlugin signPlugin(final SignService signService) { return new SignPlugin(signService); }
就是你在項目里頭注入哪個SignService實現(xiàn)類,它會塞到這插件里頭來。
它會去判斷規(guī)則是否存在,什么規(guī)則?就是驗證簽名的時候那些配置,比如說多久超時,哪些url要通過sign驗簽。
但是這里也暴露了一個問題,過度依賴配置,如果做到高可用,可以做一層backup備份,如果沒有配置,或者配置讀不到的情況下,讀取上次配置的內(nèi)容。
DefaultSignService
這里有個比較好的東西,就是會將一些內(nèi)容封裝到上下文里頭,比如說a節(jié)點,處理了一個東西,還要set一個特殊的key到header里面,然后讓后面的去拿,這就很不方便了,如果是放在上下文的話,這就統(tǒng)一處理。
驗簽邏輯開始,首先是對時間做驗證,然后再是算法驗。
這里我要直呼一聲好家伙,exchange.getRequest().getQueryParams()直接拿到請求的參數(shù),如果你在服務(wù)里面實現(xiàn)那得累死你,區(qū)分post、get請求,需要特殊處理。
buildParamsMap(shenyuContext, requestBody)
這個map里頭有啥?加了時間戳、url、版本號,請求參數(shù)(去除sign)
DigestUtils.md5DigestAsHex(sign.getBytes()).toUpperCase()
這里是sign簽名算法
總結(jié)
到這里,shenyu的sign插件邏輯就差不多了,直呼好家伙,跟我現(xiàn)在項目里頭驗簽邏輯一毛一樣,只是簽名算法有所不同。但是這里面還是有些能優(yōu)化的點,比如說過度依賴shenyu現(xiàn)有的配置內(nèi)容,需要做到網(wǎng)關(guān)點高可用~
shenyu這里跟其他配置中心也有所不一樣,采用map來接收配置內(nèi)容,我們看nacos、apolla這些框架是刷新到eventment環(huán)境變量里頭去。
以上就是shenyu怎么處理sign鑒權(quán)前置到網(wǎng)關(guān)的詳細內(nèi)容,更多關(guān)于shenyu處理sign鑒權(quán)前置網(wǎng)關(guān)的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
淺談java Iterator.remove()方法的用法(詳解)
下面小編就為大家?guī)硪黄獪\談java Iterator.remove()方法的用法(詳解)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01詳解Java中ByteArray字節(jié)數(shù)組的輸入輸出流的用法
ByteArrayInputStream和ByteArrayOutputStream分別集成自InputStream和OutputStream這兩個輸入和輸出流,這里我們就來詳解Java中ByteArray字節(jié)數(shù)組的輸入輸出流的用法,需要的朋友可以參考下2016-06-06Java 中 Date 與 Calendar 之間的編輯與轉(zhuǎn)換實例詳解
這篇文章主要介紹了Java 中 Date 與 Calendar 之間的編輯與轉(zhuǎn)換 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-07-07ibatis結(jié)合oracle批量插入三種方法的測評
今天小編就為大家分享一篇關(guān)于ibatis結(jié)合oracle批量插入三種方法的測評,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12Maven中怎么手動添加jar包到本地倉庫詳解(repository)
這篇文章主要給大家介紹了關(guān)于Maven中怎么手動添加jar包到本地倉庫的相關(guān)資料,文中通過圖文以及實例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2023-04-04Spring Boot熱加載jar實現(xiàn)動態(tài)插件的思路
本文主要介紹在 Spring Boot 工程中熱加載 jar 包并注冊成為 Bean 對象的一種實現(xiàn)思路,在動態(tài)擴展功能的同時支持在插件中注入主程序的 Bean 實現(xiàn)功能更強大的插件2021-10-10mybatis自定義參數(shù)類型轉(zhuǎn)換器數(shù)據(jù)庫字段加密脫敏
這篇文章主要為大家介紹了mybatis自定義參數(shù)類型轉(zhuǎn)換器數(shù)據(jù)庫字段加密脫敏,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09