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

實戰!微服務認證中心如何擴展授權模式實現多種方式登錄?

開發 前端
每種授權類型都對應一種TokenGranter,其中會定義授權類型的名稱,比如密碼模式的ResourceOwnerPasswordTokenGranter,其中的GRANT_TYPE為password。

本篇文章介紹一下Spring Security如何擴展新的授權類型,也是實際開發中非常重要的知識點。

目錄如下:

圖片圖片

為什么需要自定義授權類型?

前面介紹OAuth2.0的基礎知識點時介紹過支持的4種授權類型,分別如下:

  • 授權碼模式
  • 簡化模式
  • 客戶端模式
  • 密碼模式

實際生產中上述四種授權類型根本不夠用,比如常見的授權類型如下:

  • 微信認證
  • QQ認證
  • 手機號+驗證碼認證
  • 圖形驗證碼認證
  • 郵箱認證

因此我們必須懂得OAuth2.0如何自定義授權類型,這也是本篇文章的重點。

實現思路

Spring Security 定制授權類型其實很簡單,主要是掌握其中的思路,下面是密碼模式的授權流程,如下圖:

圖片圖片

根據上述流程圖可以跟著源碼進去看看,不難發現有幾個如下重要點:

  • 每種授權類型都對應一個實現類TokenGranter,其中定義著授權類型
  • 所有 TokenGranter 實現類都通過 CompositeTokenGranter 中的 tokenGranters 集合存起來。
  • 然后通過判斷 grantType 參數來定位具體使用那個 TokenGranter 實現類來處理授權。
  • 每種授權方式都對應一個AuthenticationProvider
  • TokenGranter 類會 new 一個 AuthenticationToken實現類,如 UsernamePasswordAuthenticationToken 傳給 ProviderManager 類。

因此想要自定義一個授權類型,必須構建自己的TokenGranter、AuthenticationProvider、AuthenticationToken。

代碼實現

下面就以手機號+密碼的登錄方式定義一個類型:mobile_pwd,剩下的自己照葫蘆畫瓢。

1、自定義UserDetailService

這個和密碼授權類型類似,要實現一個方法從數據庫中根據手機號查詢用戶的詳細信息。

定義一個SmsCodeUserDetailService接口如下:

圖片圖片

主要就是一個 loadUserByMobile() 方法,實現類如下:

圖片圖片

2、自定義AuthenticationToken

類似于密碼模式的中UsernamePasswordAuthenticationToken,自定義一個MobilePasswordAuthenticationToken封裝手機號和密碼,如下:

圖片圖片

3、自定義TokenGranter

每種授權類型都對應一種TokenGranter,其中會定義授權類型的名稱,比如密碼模式的ResourceOwnerPasswordTokenGranter,其中的GRANT_TYPE為password。

自定義一個MobilePwdGranter,照葫蘆畫瓢,模仿著改改,代碼如下:

圖片圖片

4、自定義AuthenticationProvider

這個類就是真正的處理類,經過TokenGranter后,會找到對應的AuthenticationProvider,然后取出參數從數據庫(UserDetailService)中查詢對應的信息進行匹配。

自定義MobilePasswordAuthenticationProvider,代碼如下:

圖片圖片

圖片圖片

案例源碼已上傳GitHub,關注公眾號:碼猿技術專欄,回復關鍵:9529 獲取!

5、將自定義的MobilePasswordAuthenticationProvider注入IOC容器

這里必須將自定義的MobilePasswordAuthenticationProvider注入到IOC容器,如果不注入,會報找不到能處理的AuthenticationProvider這個異常。

新建SmsCodeSecurityConfig,代碼如下:

圖片圖片

注意:由于使用的外部配置,因此必須在全局配置中指定

6、Security的全局配置指定SmsCodeSecurityConfig

由于是分開配置,因此必須在全局配置中指定才會生效,代碼如下:

圖片圖片

7、加到CompositeTokenGranter集合中

需要將自定義的授權類型加到集合CompositeTokenGranter中,此處需要修改認證中心的配置類(AuthorizationServerConfig)中的代碼,如下:

圖片圖片

8、oauth_client_details表中添加授權類型

oauth_client_details這個表是存儲客戶端的詳細信息的,需要在對應的客戶端資源那一行中的authorized_grant_types這個字段中添加自定義的授權類型,多個用逗號分隔。

圖片圖片

測試

經過上述的步驟已經配置完成,下面來測試,啟動服務,請求如下:

圖片圖片

源碼獲取

授權類型主要是針對 認證中心(oauth2-cloud-auth-server) 的改動,改動的目錄如下:

圖片圖片

陳某直接在之前網關整合Spring Security的源碼上更改了一版。

責任編輯:武曉燕 來源: 碼猿技術專欄
相關推薦

2022-03-03 08:51:09

微服務認證中心授權模式

2022-05-12 07:37:51

單點登錄微服務開源

2021-03-09 09:33:42

網關授權微服務

2024-06-05 06:43:20

2022-09-22 10:01:47

微服務授權認證

2024-03-18 08:48:52

Spring多端認證微服務

2020-12-17 08:10:19

身份驗證授權微服務

2023-12-29 18:53:58

微服務Saga模式

2023-09-07 23:25:34

微服務服務發現

2023-09-02 20:51:09

微服務業務服務

2021-01-07 08:43:11

微服務pipelineGitLabGroup

2022-07-13 13:34:30

微服務邊車SideCar

2022-07-22 14:32:29

賬號登錄服務鴻蒙

2022-12-19 16:51:52

AGC華為

2015-10-23 14:53:25

qq授權登陸

2025-03-31 08:35:00

Eureka微服務架構

2024-12-27 10:12:28

2023-05-31 19:10:31

2022-04-09 14:45:02

微服務常見概念Spring

2018-04-03 16:24:34

分布式方式
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 自拍偷拍中文字幕 | 天天躁日日躁狠狠躁白人 | 亚洲精品一区在线观看 | 亚洲网站在线观看 | 日本久草视频 | 日韩伦理一区二区 | 中文字幕a√ | 欧美一级做性受免费大片免费 | 亚洲国产精品久久久 | 9色网站| 男女网站视频 | 国产精品久久久久一区二区 | 一区二区三区免费观看 | 天天操夜夜操 | 久久99精品久久久久久琪琪 | 一级美国黄色片 | 99亚洲 | 成人精品 | 国产一区二区三区在线看 | 国产一区二区三区免费 | 日韩在线一区二区 | 中文字幕一区二区三区在线观看 | 午夜在线视频 | 午夜精品一区二区三区免费视频 | 国产成人精品久久二区二区91 | 欧美在线观看一区 | 欧美区日韩区 | 91久久精品国产91久久性色tv | 欧美成人一区二区 | 一区二区三区在线 | 国产日韩精品视频 | 久久精品黄色 | 亚洲三区在线观看 | 成人av网站在线观看 | 久草视频在线播放 | 国产福利91精品一区二区三区 | 免费观看一级毛片 | 免费的av网站 | 国产不卡在线观看 | 国产免费一区二区三区最新6 | 亚洲欧美日韩精品久久亚洲区 |