Step by Step帶你玩轉(zhuǎn)DuerOS - OAuth2.0全面解析 (4)

DuerOS的開發(fā)平臺(tái)在創(chuàng)建產(chǎn)品時(shí),有一步需要進(jìn)行OAuth設(shè)置(http://open.duer.baidu.com/doc/overall/console-guide_markdown)笤妙,

DuerOS OAuth配置

很多同學(xué)到這個(gè)步驟估計(jì)會(huì)很困惑冒掌,OAuth是什么噪裕?這里設(shè)置的URL有是什么呢?那我們這篇文章就好好講一講OAuth到底是什么股毫?在DuerOS的接入過程中又是怎么使用的膳音。

什么是OAuth

其實(shí)OAuth在我們?nèi)粘V惺欠浅3R姷模赡苣銢]有專門的關(guān)注過功能背后的實(shí)現(xiàn)原理铃诬。這里有一篇阮一峰老師專門介紹OAuth的文章《理解OAuth 2.0》(http://www.ruanyifeng.com/blog/2014/05/oauth_2_0.html)祭陷,這是我目前為止見得對(duì)OAuth講解最淺顯又是最全面的一篇(ps 阮一峰老師的文章質(zhì)量都很高呀)。

DuerOS是如何使用OAuth的

OAuth有4中授權(quán)模式趣席,

OAuth授權(quán)模式

而DuerOS使用的便是其中功能最完整兵志、流程最嚴(yán)密的授權(quán)碼模式。下面我們通過Python版本的DuerOS客戶端來分析下DuerOS對(duì)OAuth的使用宣肚。

認(rèn)證流程組成單元

授權(quán)碼模式的認(rèn)證流程如下所示想罕,

授權(quán)碼模式認(rèn)證流程

主要涉及到4個(gè)基本單元:

  • A-用戶客戶端
  • B-用戶端瀏覽器(完成URI重定向)
  • C-用戶客戶端對(duì)應(yīng)的后臺(tái)服務(wù)器
  • D-認(rèn)證服務(wù)器

針對(duì)于DuerOS Python客戶端,A霉涨、B按价、C、D分別對(duì)應(yīng):

  • A-auth.sh(app/auth.py)
  • B-系統(tǒng)瀏覽器
  • C-app/auth.py中創(chuàng)建的Tornado WebServer
  • D-百度的認(rèn)證服務(wù)器

OAuth認(rèn)證流程

下面我們結(jié)合代碼笙瑟,一步一步的解析OAuth的整個(gè)過程

1.用戶客戶端(A)對(duì)應(yīng)的后臺(tái)服務(wù)器(C)創(chuàng)建

運(yùn)行楼镐,

# ./auth.sh

Python客戶端會(huì)創(chuàng)建一個(gè)本地的Tornado WebServer,

Tornado WebServer創(chuàng)建(app/auth.py)

這個(gè)Tornado WebServer只是為了調(diào)試方便被部署在本地往枷,實(shí)際項(xiàng)目應(yīng)用中會(huì)作為獨(dú)立的Web服務(wù)框产,部署在云端的。

2. 客戶端(A)吊起本地瀏覽器(B)訪問客戶端對(duì)應(yīng)的后臺(tái)服務(wù)器(C)

好像有些繞(汗师溅。茅信。。)

app/auth.py

其中墓臭,URL(http://127.0.0.1:3000)就是客戶端對(duì)應(yīng)的后臺(tái)服務(wù)器(C)的地址蘸鲸。

3. 客戶端對(duì)應(yīng)的后臺(tái)服務(wù)器(C)通過重定向的方式讓客戶端瀏覽器(B)對(duì)百度認(rèn)證服務(wù)器(D)發(fā)送認(rèn)證請(qǐng)求

哎,好像更繞了(再汗窿锉。酌摇。。)

app/auth.py

4. 百度認(rèn)證服務(wù)器(D)向客戶端瀏覽器(B)返回用戶登錄頁面

用戶登錄頁面

前面的步驟嗡载,用戶客戶端(A)窑多、用戶客戶端對(duì)應(yīng)的后臺(tái)服務(wù)器(C)、百度認(rèn)證服務(wù)器(D)洼滚,三者之間的通信都需要客戶端瀏覽器(B)進(jìn)行重定向做請(qǐng)求轉(zhuǎn)發(fā)埂息。這樣的過程是不是感覺很困惑呢?為啥非要通過瀏覽器(B)來做重定向請(qǐng)求轉(zhuǎn)發(fā)呢?為啥不直接進(jìn)行Http請(qǐng)求呢千康?
現(xiàn)在看到這個(gè)頁面應(yīng)該有答案了吧:需要由瀏覽器(B)來展示來自百度認(rèn)證服務(wù)器(D)的認(rèn)證頁面享幽,并完成用戶身份認(rèn)證的交互。

5. 百度認(rèn)證服務(wù)器(D)將授權(quán)碼通過客戶端瀏覽器(B)轉(zhuǎn)發(fā)給客戶端對(duì)應(yīng)的后臺(tái)服務(wù)器(C)

用戶在第4步中輸入賬號(hào)拾弃、密碼后值桩,點(diǎn)擊登錄并授權(quán)。百度的認(rèn)證服務(wù)器(D)會(huì)收到用戶登錄請(qǐng)求豪椿,然后將授權(quán)碼通過客戶端瀏覽器(B)重定向的方式發(fā)送給客戶端對(duì)應(yīng)的后臺(tái)服務(wù)器(C)奔坟。

app/auth.py

6. 客戶端后臺(tái)服務(wù)器(C)通過授權(quán)碼向百度認(rèn)證服務(wù)器(D)請(qǐng)求Token

客戶端后臺(tái)服務(wù)器(C)通過上一步獲得的授權(quán)碼向百度認(rèn)證服務(wù)器(D)請(qǐng)求授權(quán),并獲取Token搭盾,

app/auth.py

7. 用戶客戶端(A)從客戶端的后臺(tái)服務(wù)器(C)中獲取Token

由于Python DuerOS客戶端中的后臺(tái)服務(wù)器(Tornado WebServer)就在本地咳秉,所以,Token可以直接獲得鸯隅,

8. token使用

千辛萬苦通過OAuth流程獲取的Token其實(shí)在DuerOS的后續(xù)請(qǐng)求中只是一個(gè)字段而已滴某,

請(qǐng)求中的token字段
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市滋迈,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌户誓,老刑警劉巖饼灿,帶你破解...
    沈念sama閱讀 216,544評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異帝美,居然都是意外死亡碍彭,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門悼潭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來庇忌,“玉大人,你說我怎么就攤上這事舰褪〗哉睿” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵占拍,是天一觀的道長略就。 經(jīng)常有香客問我,道長晃酒,這世上最難降的妖魔是什么表牢? 我笑而不...
    開封第一講書人閱讀 58,193評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮贝次,結(jié)果婚禮上崔兴,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好敲茄,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評(píng)論 6 388
  • 文/花漫 我一把揭開白布位谋。 她就那樣靜靜地躺著,像睡著了一般折汞。 火紅的嫁衣襯著肌膚如雪倔幼。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,182評(píng)論 1 299
  • 那天爽待,我揣著相機(jī)與錄音损同,去河邊找鬼。 笑死鸟款,一個(gè)胖子當(dāng)著我的面吹牛膏燃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播何什,決...
    沈念sama閱讀 40,063評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼组哩,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了处渣?” 一聲冷哼從身側(cè)響起伶贰,我...
    開封第一講書人閱讀 38,917評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎罐栈,沒想到半個(gè)月后黍衙,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡荠诬,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評(píng)論 2 332
  • 正文 我和宋清朗相戀三年琅翻,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片柑贞。...
    茶點(diǎn)故事閱讀 39,722評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡方椎,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出钧嘶,到底是詐尸還是另有隱情棠众,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評(píng)論 5 343
  • 正文 年R本政府宣布康辑,位于F島的核電站摄欲,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏疮薇。R本人自食惡果不足惜胸墙,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望按咒。 院中可真熱鬧迟隅,春花似錦但骨、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至吼野,卻和暖如春校哎,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背瞳步。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評(píng)論 1 269
  • 我被黑心中介騙來泰國打工闷哆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人单起。 一個(gè)月前我還...
    沈念sama閱讀 47,729評(píng)論 2 368
  • 正文 我出身青樓抱怔,卻偏偏與公主長得像,于是被迫代替她去往敵國和親嘀倒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子屈留,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評(píng)論 2 353

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

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)测蘑,斷路器灌危,智...
    卡卡羅2017閱讀 134,652評(píng)論 18 139
  • OAuth是一個(gè)關(guān)于授權(quán)(authorization)的開放網(wǎng)絡(luò)標(biāo)準(zhǔn),在全世界得到廣泛應(yīng)用碳胳,目前的版本是2.0版乍狐。...
    謝謝寫閱讀 747評(píng)論 0 1
  • OAuth是一個(gè)關(guān)于授權(quán)(authorization)的開放網(wǎng)絡(luò)標(biāo)準(zhǔn),在全世界得到廣泛應(yīng)用固逗,目前的版本是2.0版。...
    夕望有你閱讀 285評(píng)論 1 2
  • 最近發(fā)現(xiàn)公司里有很多人都不理解Oauth藕帜,而且目前國內(nèi)大部分的oauth實(shí)現(xiàn)也都是基于標(biāo)準(zhǔn)oauth2.0的改版烫罩,...
    monkey01閱讀 942評(píng)論 0 5
  • 1. 微服務(wù)架構(gòu)介紹 1.1 什么是微服務(wù)架構(gòu)? 形像一點(diǎn)來說洽故,微服務(wù)架構(gòu)就像搭積木贝攒,每個(gè)微服務(wù)都是一個(gè)零件,并使...
    靜修佛緣閱讀 6,641評(píng)論 0 39