之前寫了很多關于spring cloud的文章,今天我們對OAuth2.0的整合方式做一下筆記,首先我從網上找了一些關于OAuth2.0的一些基礎知識點,幫助大家回顧一下知識點:
一、oauth中的角色
client:調用資源服務器API的應用
Oauth 2.0 Provider:包括Authorization Server和Resource Server
(1)Authorization Server:認證服務器,進行認證和授權
(2)Resource Server:資源服務器,保護受保護的資源
user:資源的擁有者
二、下面詳細介紹一下Oauth 2.0 Provider
Authorization Server:
(1)AuthorizationEndpoint:進行授權的服務,Default URL: /oauth/authorize
(2)TokenEndpoint:獲取token的服務,Default URL: /oauth/token
Resource Server:
OAuth2AuthenticationProcessingFilter:給帶有訪問令牌的請求加載認證
三、下面再來詳細介紹一下Authorization Server:
一般情況下,創(chuàng)建兩個配置類,一個繼承AuthorizationServerConfigurerAdapter,一個繼承WebSecurityConfigurerAdapter,再去復寫里面的方法。
主要出現(xiàn)的兩種注解:
1、@EnableAuthorizationServer:聲明一個認證服務器,當用此注解后,應用啟動后將自動生成幾個Endpoint:(注:其實實現(xiàn)一個認證服務器就是這么簡單,加一個注解就搞定,當然真正用到生產環(huán)境還是要進行一些配置和復寫工作的。)
/oauth/authorize:驗證
/oauth/token:獲取token
/oauth/confirm_access:用戶授權
/oauth/error:認證失敗
/oauth/check_token:資源服務器用來校驗token
/oauth/token_key:如果jwt模式則可以用此來從認證服務器獲取公鑰
以上這些endpoint都在源碼里的endpoint包里面。
2、@Beans:需要實現(xiàn)AuthorizationServerConfigurer
AuthorizationServerConfigurer包含三種配置:
ClientDetailsServiceConfigurer:client客戶端的信息配置,client信息包括:clientId、secret、scope、authorizedGrantTypes、authorities
(1)scope:表示權限范圍,可選項,用戶授權頁面時進行選擇
(2)authorizedGrantTypes:有四種授權方式
Authorization Code:用驗證獲取code,再用code去獲取token(用的較多的方式,也是較安全的方式)
Implicit: 隱式授權模式
Client Credentials (用來** App Access Token)
Resource Owner Password Credentials
(3)authorities:授予client的權限
這里的具體實現(xiàn)有多種,in-memory、JdbcClientDetailsService、jwt等。
AuthorizationServerSecurityConfigurer:聲明安全約束,哪些允許訪問,哪些不允許訪問
AuthorizationServerEndpointsConfigurer:聲明授權和token的端點以及token的服務的一些配置信息,比如采用什么存儲方式、token的有效期等
client的信息的讀?。涸?/span>ClientDetailsServiceConfigurer類里面進行配置,可以有in-memory、jdbc等多種讀取方式。
jdbc需要調用JdbcClientDetailsService類,此類需要傳入相應的DataSource.
下面再介紹一下如何管理token:
AuthorizationServerTokenServices接口:聲明必要的關于token的操作
(1)當token創(chuàng)建后,保存起來,以便之后的接受訪問令牌的資源可以引用它。
(2)訪問令牌用來加載認證
接口的實現(xiàn)也有多種,DefaultTokenServices是其默認實現(xiàn),他使用了默認的InMemoryTokenStore,不會持久化token;
token存儲方式共有三種分別是:
(1)InMemoryTokenStore:存放內存中,不會持久化
(2)JdbcTokenStore:存放數(shù)據庫中
(3)Jwt: json web token
授權類型:
可以通過AuthorizationServerEndpointsConfigurer來進行配置,默認情況下,支持除了密碼外的所有授權類型。相關授權類型的一些類:
(1)authenticationManager:直接注入一個AuthenticationManager,自動開啟密碼授權類型
(2)userDetailsService:如果注入UserDetailsService,那么將會啟動刷新token授權類型,會判斷用戶是否還是存活的
(3)authorizationCodeServices:AuthorizationCodeServices的實例,auth code 授權類型的服務
(4)implicitGrantService:imlpicit grant
(5)tokenGranter:
endpoint的URL的配置:
(1)AuthorizationServerEndpointsConfigurer的pathMapping()方法,有兩個參數(shù),**個是默認的URL路徑,*二個是自定義的路徑
(2)WebSecurityConfigurer的實例,可以配置哪些路徑不需要保護,哪些需要保護。默認全都保護。
自定義UI:
(1)有時候,我們可能需要自定義的登錄頁面和認證頁面。登陸頁面的話,只需要創(chuàng)建一個login為前綴名的網頁即可,在代碼里,設置為允許訪問,這樣,系統(tǒng)會自動執(zhí)行你的登陸頁。此登陸頁的action要注意一下,必須是跳轉到認證的地址。
(2)另外一個是授權頁,讓你勾選選項的頁面。此頁面可以參考源碼里的實現(xiàn),自己生成一個controller的類,再創(chuàng)建一個對應的web頁面即可實現(xiàn)自定義的功能。
下面梳理一下授權獲取token流程:
(1)端口號換成你自己的認證服務器的端口號,client_id也換成你自己的,response_type類型為code。
localhost:8080/uaa/oauth/authorize?client_id=client&response_type=code&redirect_uri=
(2)這時候你將獲得一個code值:
(3)使用此code值來獲取較終的token:
curl -X POST -H "Cant-Type: application/x-www-form-urlencoded" -d 'grant_type=authorization_code&code=G0C20Z&redirect_uri=m' "http://client:secret@localhost:8080/uaa/oauth/token"
返回值:
{"access_token":"b251b453-cc08-4520-9dd0-9aedf58e6ca3","token_type":"bearer","expires_in":2591324,"scope":"app"}
(4)用此token值來調用資源服務器內容(如果資源服務器和認證服務器在同一個應用中,那么資源服務器會自己解析token值,如果不在,那么你要自己去做處理)
curl -H "Authorization: Bearer b251b453-cc08-4520-9dd0-9aedf58e6ca3" "localhost:8081/service2(此處換上你自己的url)"
四、Resource Server:保護資源,需要令牌才能訪問
在配置類上加上注解@EnableResourceServer即啟動。使用ResourceServerConfigurer進行配置:
(1)tokenServices:ResourceServerTokenServices的實例,聲明了token的服務
(2)resourceId:資源Id,由auth Server驗證。
(3)其它一些擴展點,比如可以從請求中提取token的tokenExtractor
(4)一些自定義的資源保護配置,通過HttpSecurity來設置
使用token的方式也有兩種:
(1)Bearer Token(https傳輸方式保證傳輸過程的安全):主流
(2)Mac(http+sign)
如何訪問資源服務器中的API?
如果資源服務器和授權服務器在同一個應用程序中,并且您使用DefaultTokenServices,那么您不必太考慮這一點,因為它實現(xiàn)所有必要的接口,因此它是自動一致的。如果您的資源服務器是一個單獨的應用程序,那么您必須確保您匹配授權服務器的功能,并提供知道如何正確解碼令牌的ResourceServerTokenServices。與授權服務器一樣,您可以經常使用DefaultTokenServices,并且選項大多通過TokenStore(后端存儲或本地編碼)表示。
(1)在校驗request中的token時,使用RemoteTokenServices去調用AuthServer中的/auth/check_token。
(2)共享數(shù)據庫,使用Jdbc存儲和校驗token,避免再去訪問AuthServer。
(3)使用JWT簽名的方式,資源服務器自己直接進行校驗,不借助任何中間媒介。
五、oauth client
在客戶端獲取到token之后,想去調用下游服務API時,為了能將token進行傳遞,可以使用RestTemplate.然后使用restTemplate進行調用Api。
注:
scopes和authorities的區(qū)別:
scopes是client權限,至少授予一個scope的權限,否則報錯。
authorities是用戶權限。
以上是我從網上找到的一篇寫的不錯的博客,希望可以幫助大家快速了解OAuth2.0,下一篇文章我們正式介紹OAuth2.0在當前框架中的使用。
從現(xiàn)在開始,我這邊會將近期研發(fā)的spring cloud微服務云架構的搭建過程和精髓記錄下來,幫助更多有興趣研發(fā)spring cloud框架的朋友,大家來一起探討spring cloud架構的搭建過程及如何運用于企業(yè)項目。完整項目的源碼來源
詞條
詞條說明
B2B2C商城系統(tǒng)解決方案,多種模式讓平臺運營較靈活多變
摘要: RedPigMall B2B2C綜合商城系統(tǒng)是專為企業(yè)級客戶研發(fā)支持多供貨商、多商戶店鋪入駐的綜合商城平臺,集團購、電商零售、批發(fā)于一體,提供給供應商商品售賣服務,對用戶提供購買服務,支持運營、聯(lián)營、招商等多種運營模式,讓企業(yè)低成本快速構建在線商城,開啟電子商... RedPigMall B2B2C綜合商城系統(tǒng)是專為企業(yè)級客戶研發(fā)支持多供貨商、多商戶店鋪入駐的綜合商城平臺,集團購、電商零售
(十一)Java springcloud B2B2C o2o多用戶商城 springcloud架構- - SSO單點登錄之OAuth2.0登錄流程(2)
之前寫了很多關于spring cloud的文章,今天我們對OAuth2.0的整合方式做一下筆記,首先我從網上找了一些關于OAuth2.0的一些基礎知識點,幫助大家回顧一下知識點:?一、oauth中的角色client:調用資源服務器API的應用Oauth 2.0 Provider:包括Authorization Server和Resource Server(1)Authorization
java springboot b2b2c shop 多用戶商城系統(tǒng)源碼-SpringCloud架構設計
較近一直在針對SpringCloud框架做項目,從中踩了不少的坑,也漸漸梳理出了一些內容,由于SpringCloud作為一個全家桶,其中東西太多,所以這時候就要有所取舍,這里就想把自己比較常用組件及架構推薦上來。需要JAVA Spring Cloud大型企業(yè)分布式微服務云構建的B2B2C電子商務平臺源碼針對這個架構圖我分層介紹一下:1、是web服務器的選型,這個我選擇的是nginx+keepali
java電商 商城 微商城 b2b2c多商戶電商 二次開發(fā)源碼PC版+wap版
系統(tǒng)具有統(tǒng)一后臺管理、部署文檔、操作文檔、開發(fā)文檔、數(shù)據庫腳本、數(shù)據字典、開發(fā)快速上手說明等文檔。代碼在Action類中注釋清晰,Service層和Dao層面向接口的開發(fā)技術簡單易學,使您能夠快速上手開發(fā)。系統(tǒng)支持的支付方式:系統(tǒng)支持的支付方式:平臺統(tǒng)一支付(收款到平臺賬戶,賣家申請?zhí)岈F(xiàn)后財務打款給賣家)和店鋪支付(直接收款到賣家自己的賬戶)系統(tǒng)支持的在線支付方式:PC端(見PayTools.ja
公司名: 無錫紅豬網絡科技有限公司
聯(lián)系人: 周慶達
電 話:
手 機: 17503009512
微 信: 17503009512
地 址: 江蘇無錫濱湖區(qū)222號
郵 編: 123123
¥300000.00
生產企業(yè) 河北創(chuàng)新的設備運行維護管理解決方案
¥12800.00
¥1386.00
嘉科科技PCB板行業(yè)質量追溯系統(tǒng)定制開發(fā)
¥300000.00
¥10000.00