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

Java架構(gòu)-SpringCloud分布式架構(gòu)權(quán)限管理

開發(fā) 后端 新聞 分布式
本文討論分布式架構(gòu)權(quán)限管理的兩種情況,一種是針對統(tǒng)一授權(quán)訪問的,一種是跨平臺接口訪問的。

 概述

本文討論分布式架構(gòu)權(quán)限管理的兩種情況,一種是針對統(tǒng)一授權(quán)訪問的,一種是跨平臺接口訪問的。

[[271166]]

雖然分布式架構(gòu)會做業(yè)務(wù)的切割,將整體的業(yè)務(wù)切割為獨立的子業(yè)務(wù)或者子平臺,但是同一平臺下往往會有統(tǒng)一的授權(quán)和單點登錄,客戶端而言平臺是整體的,這種是統(tǒng)一授權(quán)訪問的權(quán)限管理。但是也會遇到多平臺協(xié)作的情況,這種情況不用考慮其他平臺的架構(gòu),只需要為其提供數(shù)據(jù)接口跟其對接就可以,這種情況就要考慮跨平臺接口訪問的權(quán)限管理。

一、統(tǒng)一授權(quán)訪問

前端采用web服務(wù)器,nginx或者haproxy之類的都可以,利用nginx做第一層反向代理,用zuul做第二層反向代理,兩層反向代理對于常見的網(wǎng)絡(luò)滲透和爬蟲基本可以輕松應(yīng)對。在這個前提下,我們處理接口授權(quán)和訪問安全等問題,而且需要從客戶端和服務(wù)端都進行安全控制。

Java架構(gòu)-SpringCloud分布式架構(gòu)權(quán)限管理

1、用戶通過用戶名、密碼發(fā)起登陸請求,這里可以配合驗證碼、短信驗證、微信驗證等提高安全級別,登陸請求訪問到權(quán)限中心的ZUUL。

2、由ZUUL反向代理到權(quán)限中心的SERVICE。

3、查詢用戶、角色信息,進行查詢匹配。

4、有查詢結(jié)果以后反饋,反饋用戶狀態(tài),用戶、角色、權(quán)限信息等。

5、生產(chǎn)TOKEN,TOKEN的算法需要自己編寫,建議加入時間戳等信息進行加密。存放在SESSION或者直接放入REDIS中,一般建議放入SESSION中,因為分布式架構(gòu)要做SESSION共享,必須有一個SESSION共享池,SESSION共享池一般會用REDIS來做,而SESSION可以利用SESSIONID,確認唯一用戶,比較方便。

6、返回給客戶端用戶、角色、權(quán)限信息。

7、瀏覽器客戶端通過得到的用戶、角色、權(quán)限信息進行前端功能和菜單的渲染,隱藏非授權(quán)的功能,并且可以基于這些信息做前端的校驗,但是這種校驗由于都在客戶端,很容易被人篡改,只能做一些基本防護,但是這是必要的。

8、瀏覽器客戶端發(fā)送業(yè)務(wù)請求到服務(wù)端,請求會附帶客戶端菜單或者功能的權(quán)限信息,服務(wù)端通過ZUUL的攔截器攔截業(yè)務(wù)請求,訪問SESSION共享池。

9、然后通過SESSIONID得到TOKEN信息,通過我們的TOKEN算法進行解密,得到用戶、角色、權(quán)限信息。

10、進行匹配校驗,查看本次請求是否有接口訪問權(quán)限,校驗通過就可以訪問接口,校驗不通過就不能訪問。

二、跨平臺接口訪問

這里的接口是指一下跨平臺的接口服務(wù),類似webservice這樣,沒有單點登錄,沒有統(tǒng)一的授權(quán),往往是其他平臺跟我們平臺進行遠程交互的,這些往往兩個平臺不是統(tǒng)一的公司或部門,所以接口不是長期使用的,有一定的時間限制。

Java架構(gòu)-SpringCloud分布式架構(gòu)權(quán)限管理

1、用戶管理員配置外部客戶端用戶及其權(quán)限信息。

2、添加用戶信息、權(quán)限信息到用戶數(shù)據(jù)庫之中。

3、外部客戶端接口如果沒有TOKEN,需要先發(fā)送授權(quán)請求到權(quán)限中心。

4、權(quán)限中心通過驗證是否配置外部客戶端用戶,并且取得該用戶的權(quán)限信息,校驗通過以后通過加密算法生產(chǎn)TOKEN,這里的TOKEN根據(jù)實際情況,如果安全要求高最好加入時間戳,讓TOKEN過期作廢,讓對方重新請求。

5、將TOKEN存入REDIS中,形成TOKEN共享池,這里由于沒有瀏覽器的SESSIONID,所以存放在SESSION中意義不大。

6、返回TOKEN給客戶端。

7、客戶端拿到TOKEN以后發(fā)送業(yè)務(wù)請求給業(yè)務(wù)接口地址。

8、業(yè)務(wù)接口通過ZUUL攔截請求,并且將TOKEN跟REDIS的TOKEN進行比對。

9、比對成功以后,對TOKEN進行解密,然后看是否有接口授權(quán)。

10、如果有接口授權(quán)則通過,訪問接口,如果沒有則不能訪問。

Java高級資料需要自己領(lǐng)取,涵蓋了Java、Redis、MongoDB、MySQL、Zookeeper、Spring Cloud、Dubbo高并發(fā)分布式等教程!!!

責(zé)任編輯:華軒 來源: 今日頭條
相關(guān)推薦

2019-07-19 08:46:58

2023-05-29 14:07:00

Zuul網(wǎng)關(guān)系統(tǒng)

2019-10-10 09:16:34

Zookeeper架構(gòu)分布式

2025-02-14 08:50:00

架構(gòu)開發(fā)軟件

2017-10-30 08:52:27

vSAN架構(gòu)RAID

2022-03-06 21:43:05

Citus架構(gòu)PostgreSQL

2011-03-11 16:02:05

2023-09-12 22:58:51

分布式架構(gòu)微服務(wù)

2018-04-19 10:46:39

3N層框架

2017-03-14 11:52:52

微服務(wù)架構(gòu)數(shù)據(jù)管理

2018-04-03 09:27:42

分布式架構(gòu)系統(tǒng)

2017-07-26 14:55:32

分布式技術(shù)架構(gòu)

2017-05-08 11:53:21

2020-06-02 14:45:48

PostgreSQL架構(gòu)分布式

2025-05-13 03:22:00

2017-12-20 16:15:30

分布式系統(tǒng)架構(gòu)

2019-12-26 08:59:20

Redis主從架構(gòu)

2021-07-03 19:21:50

架構(gòu)分布式系統(tǒng)

2018-12-14 10:06:22

緩存分布式系統(tǒng)

2014-05-23 10:30:25

負載均衡分布式架構(gòu)
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 国产精品视频中文字幕 | 国产午夜精品一区二区三区 | 99色播| 精品久久一区 | 一区二区三区四区视频 | av网站免费在线观看 | 99自拍视频| 91国内精精品久久久久久婷婷 | 欧美成人免费在线视频 | 国产精品亚洲视频 | 国产福利在线视频 | 亚洲一区久久 | 在线日韩中文字幕 | 亚洲综合小视频 | 欧美精品一区二区三区在线播放 | 久久国产精品亚洲 | 超碰在线免费公开 | 久久亚洲视频网 | 成人欧美一区二区三区在线播放 | 成人午夜精品 | 国产午夜精品一区二区三区嫩草 | 国产一区二区三区精品久久久 | 久久新 | av第一页 | av av在线| 欧美日韩视频 | 国产精品无 | 久久精品亚洲精品国产欧美 | 欧美女优在线观看 | 久草欧美视频 | 亚洲首页 | 午夜成人免费视频 | www.887色视频免费 | 亚洲成av | 一区二区三区国产精品 | 精品一区电影 | 情侣av| 国产精品福利久久久 | 国产99久久 | 国产精品久久久久久久久免费丝袜 | 中文福利视频 |