laravel5.3 源碼分析 Passport

laravel5.3钠绍,密碼模式的授權認證過程媒熊。我會通過兩部分內(nèi)容分享以及查看passport的認證流程分享出來

第一部分:根據(jù)官方文檔宏胯,通過Composer安裝Passport

文檔地址:http://laravelacademy.org/post/5993.html

第二部分 認證流程

認證流程,我主要從兩方面入手

? ? ? ?首先是添加這個Passport包肢专,在config/app.php中的providers數(shù)組中添加的Laravel\Passport\PassportServiceProvider::class服務巾乳,具體注冊了哪些服務

? ? ? ?然后根據(jù)認證路由,從請求路由開始鸟召,到最終實現(xiàn)胆绊,跟進代碼閱讀路程

1. Passport服務提供者:

使用這個Passport服務之前,首先需要了解服務提供者的作用欧募,按照文檔的介紹压状,服務提供者是整個應用的啟動中心,主要是通過register方法注冊一些實例到容器中跟继,在config/app.php的providers數(shù)組中种冬,添加

在這個PassportServiceProvider類中,注冊需要用的實例到容器中

此服務需要注冊的事物舔糖,

分別注冊認證服務娱两,資源服務,令牌

分別先看下這些方法都注冊了哪些內(nèi)容

定義一個AuthorizationServer::class的實現(xiàn)

在這個實現(xiàn)中金吗,跟進tap的方法是將第一個參數(shù)作為第二個回調(diào)函數(shù)的參數(shù)的參數(shù)十兢,最后返回該回調(diào)函數(shù)的值

tap函數(shù)的第一個參數(shù)是$this->makeAuthorizationServer()調(diào)用的返回值

返回一個認證服務類的實例

這個$this->app就是容器的實例,make方法就是通過傳進來的接口類摇庙,得到此接口的實現(xiàn)類的對象旱物。在AuthorizationServer類的構(gòu)造函數(shù)中,賦值給類中的成員變量

回到tap方法卫袒,將得到的這個認證服務實例傳到這個回調(diào)函數(shù)中

這個$server就是第一個參數(shù)返回的認證服務AuthorizationServer類的對象

調(diào)用AuthorizationServer類中的enableGrantType方法,這個方法中我的理解就是啟動各個oauth授權方式宵呛,實例化各個授權方式的類,傳到這個方法中夕凝,將在實例化AuthorizationServer類的時候宝穗,賦值的那些成員變量的值,再賦值給這里的每項授權方式對象中码秉,如圖

$grantType就是相應的授權方式的類

最后在將各個授權方式的對象逮矛,保存在enabledGrantTypes數(shù)組中,其中key就是每個對象內(nèi)部的getIdentifier()方法返回的字符串泡徙。

到此橱鹏,就是Passport服務提供者,注冊的第一部分內(nèi)容了堪藐,即認證服務相關內(nèi)容

2. 查看路由的執(zhí)行過程

這個時候就用到了在安裝Passport配置的路由項了

在文檔中可以找到此配置項

那么就看下這個routes()靜態(tài)方法是如何實現(xiàn)的

這段代碼莉兰,實際上就是執(zhí)行了RouteRegisterar類中的all()方法

跟進各個方法,發(fā)現(xiàn)都是一些路由

我用到的密碼模式的路由在這個forAccessTokens()方法中

現(xiàn)在找到了路由礁竞,接下來就可以到相應的控制器中看糖荒,具體如何實現(xiàn)認證過程

3. 認證過程

在這個Passport包中找到認證的控制器

在這個控制器中,可以看到通過用戶賬號認證客戶端的方法

這里的$this->server就是服務提供者中注冊的AuthorizationServer類的對象了
在這個方法中首先校驗了請求令牌是否存在

在這個方法中循環(huán)enabledGrantTypes數(shù)組模捂,這個數(shù)組是在注冊認證服務的時候捶朵,填的內(nèi)容,存的所有認證授權方式的類的對象狂男,先判斷請求中的grant_type字段是否存在综看,不存在返回下面錯誤

grant_type錯誤的請求

存在的話,執(zhí)行相應類的respondToAccessTokenRequest方法岖食,這里是密碼授權方式红碑,所以這個$grantType應該是到PasswordGrant類的實例。

密碼認證的授權類

到此類中的respondToAccessTokenRequest方法

在這個方法中泡垃,以此校驗請求參數(shù)析珊,認證請求域,驗證用戶賬號和密碼

在此處校驗用戶的賬號和密碼的時候蔑穴,除了校驗參數(shù)是否存在,還會檢驗該用戶憑證是否存在忠寻,最后返回這個類的對象

那么在校驗用戶憑證的時候,都具體做了些什么呢

在這個方法中:

1. 獲取auth.providers.users.model配置存和,在config/auth.php中

獲取User模型

注意一點:修改了默認的User模型路徑奕剃,相應要改動這個配置

2. 判斷是否存在 findForPassport()方法,如果存在捐腿,則調(diào)用這個方法來判斷存在此用戶祭饭,所以如果需要在實現(xiàn)此認證的時候用自定義的方法,比如表字段不是email的話叙量,需要定義此方法來實現(xiàn)

3. 校驗用戶的賬號密碼是否正確

如果想用自定義的方法來校驗倡蝙,同樣需要定義validateForPassportPasswordGrant來實現(xiàn)

認證成功的話,返回到respondToAccessTokenRequest()方法中绞佩,如下方法

生成access_token和refresh_token

繼續(xù)跟進issueAccessToken方法中實現(xiàn)的內(nèi)容

得到一個$accessToken變量寺鸥,是AccessToken.php類的一個對象

然后給該對象中的成員變量賦值,最后調(diào)用$this->accessTokenRepository->persisNewAccessToken方法

在這個方法中品山,將賦值剛剛賦值的那些值保存到oauth_access_tokens中

issueRefreshToken()生成refresh_token類似方法保存到oauth_refresh_tokens表中

最后將得到的access_token和refresh_token,賦值到$responseType保存的對象中胆建,$responseType是在被調(diào)用的上一層中new BearerTokenResponse()得來的

返回$responseType對象

最后又回到了respondToAccessTokenRequest()方法中

調(diào)用BearerTokenResponse()類的generateHttpResponse方法,返回認證成功的數(shù)據(jù)

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末肘交,一起剝皮案震驚了整個濱河市笆载,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖凉驻,帶你破解...
    沈念sama閱讀 212,383評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件腻要,死亡現(xiàn)場離奇詭異,居然都是意外死亡涝登,警方通過查閱死者的電腦和手機雄家,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,522評論 3 385
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來胀滚,“玉大人趟济,你說我怎么就攤上這事⊙柿” “怎么了顷编?”我有些...
    開封第一講書人閱讀 157,852評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長剑刑。 經(jīng)常有香客問我媳纬,道長,這世上最難降的妖魔是什么叛甫? 我笑而不...
    開封第一講書人閱讀 56,621評論 1 284
  • 正文 為了忘掉前任层宫,我火速辦了婚禮,結(jié)果婚禮上其监,老公的妹妹穿的比我還像新娘萌腿。我一直安慰自己,他們只是感情好抖苦,可當我...
    茶點故事閱讀 65,741評論 6 386
  • 文/花漫 我一把揭開白布毁菱。 她就那樣靜靜地躺著,像睡著了一般锌历。 火紅的嫁衣襯著肌膚如雪贮庞。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,929評論 1 290
  • 那天究西,我揣著相機與錄音窗慎,去河邊找鬼。 笑死卤材,一個胖子當著我的面吹牛遮斥,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播扇丛,決...
    沈念sama閱讀 39,076評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼术吗,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了帆精?” 一聲冷哼從身側(cè)響起较屿,我...
    開封第一講書人閱讀 37,803評論 0 268
  • 序言:老撾萬榮一對情侶失蹤隧魄,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后隘蝎,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體购啄,經(jīng)...
    沈念sama閱讀 44,265評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,582評論 2 327
  • 正文 我和宋清朗相戀三年末贾,在試婚紗的時候發(fā)現(xiàn)自己被綠了闸溃。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片整吆。...
    茶點故事閱讀 38,716評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡拱撵,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出表蝙,到底是詐尸還是另有隱情拴测,我是刑警寧澤,帶...
    沈念sama閱讀 34,395評論 4 333
  • 正文 年R本政府宣布府蛇,位于F島的核電站集索,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏汇跨。R本人自食惡果不足惜务荆,卻給世界環(huán)境...
    茶點故事閱讀 40,039評論 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望穷遂。 院中可真熱鬧函匕,春花似錦、人聲如沸蚪黑。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽忌穿。三九已至抒寂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間掠剑,已是汗流浹背屈芜。 一陣腳步聲響...
    開封第一講書人閱讀 32,027評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留朴译,地道東北人井佑。 一個月前我還...
    沈念sama閱讀 46,488評論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像动分,于是被迫代替她去往敵國和親毅糟。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,612評論 2 350

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理澜公,服務發(fā)現(xiàn)姆另,斷路器喇肋,智...
    卡卡羅2017閱讀 134,637評論 18 139
  • 國家電網(wǎng)公司企業(yè)標準(Q/GDW)- 面向?qū)ο蟮挠秒娦畔?shù)據(jù)交換協(xié)議 - 報批稿:20170802 前言: 排版 ...
    庭說閱讀 10,934評論 6 13
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,841評論 25 707
  • 4號 專家姓名:王儉 主題: 中醫(yī)調(diào)治痰咳諸證的體驗 11號專家姓名:王天峻 主題:中醫(yī)腦病理論在婦科疾病上的運用...
    黃國健博士閱讀 244評論 0 0
  • 希望有一天媽媽變成只能依賴我一個人來生活,沒有我就什么也做不到迹辐,這樣她就再也不會拿誰誰誰和我比較了蝶防,因為他們都養(yǎng)不...
    今天也好想死啊閱讀 212評論 0 0