欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談OAuth 2.0 的一個(gè)簡(jiǎn)單解釋

 更新時(shí)間:2020年10月27日 10:04:36   作者:阮一峰  
這篇文章主要介紹了淺談OAuth 2.0 的一個(gè)簡(jiǎn)單解釋,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

這個(gè)標(biāo)準(zhǔn)比較抽象,使用了很多術(shù)語(yǔ),初學(xué)者不容易理解。其實(shí)說(shuō)起來(lái)并不復(fù)雜,下面我就通過(guò)一個(gè)簡(jiǎn)單的類比,幫助大家輕松理解,OAuth 2.0 到底是什么。

一、快遞員問(wèn)題

我住在一個(gè)大型的居民小區(qū)。

小區(qū)有門禁系統(tǒng)。

進(jìn)入的時(shí)候需要輸入密碼。

我經(jīng)常網(wǎng)購(gòu)和外賣,每天都有快遞員來(lái)送貨。我必須找到一個(gè)辦法,讓快遞員通過(guò)門禁系統(tǒng),進(jìn)入小區(qū)。

如果我把自己的密碼,告訴快遞員,他就擁有了與我同樣的權(quán)限,這樣好像不太合適。萬(wàn)一我想取消他進(jìn)入小區(qū)的權(quán)力,也很麻煩,我自己的密碼也得跟著改了,還得通知其他的快遞員。

有沒(méi)有一種辦法,讓快遞員能夠自由進(jìn)入小區(qū),又不必知道小區(qū)居民的密碼,而且他的唯一權(quán)限就是送貨,其他需要密碼的場(chǎng)合,他都沒(méi)有權(quán)限?

二、授權(quán)機(jī)制的設(shè)計(jì)

于是,我設(shè)計(jì)了一套授權(quán)機(jī)制。

第一步,門禁系統(tǒng)的密碼輸入器下面,增加一個(gè)按鈕,叫做"獲取授權(quán)"??爝f員需要首先按這個(gè)按鈕,去申請(qǐng)授權(quán)。

第二步,他按下按鈕以后,屋主(也就是我)的手機(jī)就會(huì)跳出對(duì)話框:有人正在要求授權(quán)。系統(tǒng)還會(huì)顯示該快遞員的姓名、工號(hào)和所屬的快遞公司。

我確認(rèn)請(qǐng)求屬實(shí),就點(diǎn)擊按鈕,告訴門禁系統(tǒng),我同意給予他進(jìn)入小區(qū)的授權(quán)。

第三步,門禁系統(tǒng)得到我的確認(rèn)以后,向快遞員顯示一個(gè)進(jìn)入小區(qū)的令牌(access token)。令牌就是類似密碼的一串?dāng)?shù)字,只在短期內(nèi)(比如七天)有效。

第四步,快遞員向門禁系統(tǒng)輸入令牌,進(jìn)入小區(qū)。

有人可能會(huì)問(wèn),為什么不是遠(yuǎn)程為快遞員開門,而要為他單獨(dú)生成一個(gè)令牌?這是因?yàn)榭爝f員可能每天都會(huì)來(lái)送貨,第二天他還可以復(fù)用這個(gè)令牌。另外,有的小區(qū)有多重門禁,快遞員可以使用同一個(gè)令牌通過(guò)它們。

三、互聯(lián)網(wǎng)場(chǎng)景

我們把上面的例子搬到互聯(lián)網(wǎng),就是 OAuth 的設(shè)計(jì)了。

首先,居民小區(qū)就是儲(chǔ)存用戶數(shù)據(jù)的網(wǎng)絡(luò)服務(wù)。比如,微信儲(chǔ)存了我的好友信息,獲取這些信息,就必須經(jīng)過(guò)微信的"門禁系統(tǒng)"。

其次,快遞員(或者說(shuō)快遞公司)就是第三方應(yīng)用,想要穿過(guò)門禁系統(tǒng),進(jìn)入小區(qū)。

最后,我就是用戶本人,同意授權(quán)第三方應(yīng)用進(jìn)入小區(qū),獲取我的數(shù)據(jù)。

簡(jiǎn)單說(shuō),OAuth 就是一種授權(quán)機(jī)制。數(shù)據(jù)的所有者告訴系統(tǒng),同意授權(quán)第三方應(yīng)用進(jìn)入系統(tǒng),獲取這些數(shù)據(jù)。系統(tǒng)從而產(chǎn)生一個(gè)短期的進(jìn)入令牌(token),用來(lái)代替密碼,供第三方應(yīng)用使用。

四、令牌與密碼

令牌(token)與密碼(password)的作用是一樣的,都可以進(jìn)入系統(tǒng),但是有三點(diǎn)差異。

(1)令牌是短期的,到期會(huì)自動(dòng)失效,用戶自己無(wú)法修改。密碼一般長(zhǎng)期有效,用戶不修改,就不會(huì)發(fā)生變化。

(2)令牌可以被數(shù)據(jù)所有者撤銷,會(huì)立即失效。以上例而言,屋主可以隨時(shí)取消快遞員的令牌。密碼一般不允許被他人撤銷。

(3)令牌有權(quán)限范圍(scope),比如只能進(jìn)小區(qū)的二號(hào)門。對(duì)于網(wǎng)絡(luò)服務(wù)來(lái)說(shuō),只讀令牌就比讀寫令牌更安全。密碼一般是完整權(quán)限。

上面這些設(shè)計(jì),保證了令牌既可以讓第三方應(yīng)用獲得權(quán)限,同時(shí)又隨時(shí)可控,不會(huì)危及系統(tǒng)安全。這就是 OAuth 2.0 的優(yōu)點(diǎn)。

注意,只要知道了令牌,就能進(jìn)入系統(tǒng)。系統(tǒng)一般不會(huì)再次確認(rèn)身份,所以令牌必須保密,泄漏令牌與泄漏密碼的后果是一樣的。 這也是為什么令牌的有效期,一般都設(shè)置得很短的原因。

OAuth 2.0 對(duì)于如何頒發(fā)令牌的細(xì)節(jié),規(guī)定得非常詳細(xì)。具體來(lái)說(shuō),一共分成四種授權(quán)類型(authorization grant),即四種頒發(fā)令牌的方式,適用于不同的互聯(lián)網(wǎng)場(chǎng)景。下一篇文章,我就來(lái)介紹這四種類型,并給出代碼實(shí)例。

到此這篇關(guān)于淺談OAuth 2.0 的一個(gè)簡(jiǎn)單解釋的文章就介紹到這了,更多相關(guān)OAuth 2.0內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • thymeleaf實(shí)現(xiàn)th:each雙重多重嵌套功能

    thymeleaf實(shí)現(xiàn)th:each雙重多重嵌套功能

    今天給大家分享一個(gè)使用 thymeleaf 實(shí)現(xiàn)一個(gè)動(dòng)態(tài)加載一二級(jí)文章分類的功能,本文通過(guò)代碼講解的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2019-11-11
  • 字符編碼詳解及由來(lái)(UNICODE,UTF-8,GBK) 比較詳細(xì)

    字符編碼詳解及由來(lái)(UNICODE,UTF-8,GBK) 比較詳細(xì)

    很久很久以前,有一群人,他們決定用8個(gè)可以開合的晶體管來(lái)組合成不同的狀態(tài),以表示世界上的萬(wàn)物。他們看到8個(gè)開關(guān)狀態(tài)是好的,于是他們把這稱為字節(jié)
    2012-04-04
  • HTTP提交方式之PUT詳細(xì)介紹及POST和PUT的區(qū)別

    HTTP提交方式之PUT詳細(xì)介紹及POST和PUT的區(qū)別

    這篇文章主要介紹了HTTP提交方式之PUT詳細(xì)介紹及POST和PUT的區(qū)別,本文簡(jiǎn)潔易懂,需要的朋友可以參考下
    2014-07-07
  • Vscode編輯器的巧妙用法(快速格式化代碼的方法)

    Vscode編輯器的巧妙用法(快速格式化代碼的方法)

    今天小編給大家分享一款超好用的格式化神器,Vscode編輯器是一款很好用的編輯器,學(xué)會(huì)這個(gè)神器可以省去很多麻煩不需要手動(dòng)一點(diǎn)點(diǎn)縮進(jìn),對(duì)Vscode編輯器代碼格式化感興趣的朋友一起看看吧
    2021-05-05
  • Halcon讀取json文件實(shí)現(xiàn)示例

    Halcon讀取json文件實(shí)現(xiàn)示例

    這篇文章主要為大家介紹了Halcon讀取json文件實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • Archlinux?Timeshift系統(tǒng)備份與還原的操作方法

    Archlinux?Timeshift系統(tǒng)備份與還原的操作方法

    這篇文章主要介紹了Archlinux?Timeshift系統(tǒng)備份與還原的操作方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01
  • chatgpt成功解決Access denied 1020錯(cuò)誤問(wèn)題(最新推薦)

    chatgpt成功解決Access denied 1020錯(cuò)誤問(wèn)題(最新推薦)

    從前兩天網(wǎng)上開始一直開著的chatgpt網(wǎng)頁(yè)突然打不開了,提示1020錯(cuò)誤,嘗試換了不同代理軟件或者代理地點(diǎn)仍然無(wú)法解決,這篇文章主要介紹了chatgpt成功解決Access denied 1020錯(cuò)誤,需要的朋友可以參考下
    2023-05-05
  • 初探 SOA

    初探 SOA

    SOA服務(wù)具有平臺(tái)獨(dú)立的自我描述XML文檔。Web服務(wù)描述語(yǔ)言(WSDL, Web Services Description Language)是用于描述服務(wù)的標(biāo)準(zhǔn)語(yǔ)言。
    2009-01-01
  • 大數(shù)據(jù)就業(yè)的三大方向和最熱門十大崗位【推薦】

    大數(shù)據(jù)就業(yè)的三大方向和最熱門十大崗位【推薦】

    這篇文章主要介紹了大數(shù)據(jù)就業(yè)的三大方向和最熱門十大崗位,需要的朋友可以參考下
    2019-06-06
  • Mac下更換Homebrew鏡像源的實(shí)現(xiàn)方法

    Mac下更換Homebrew鏡像源的實(shí)現(xiàn)方法

    本文主要介紹了Mac下更換Homebrew鏡像源的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-07-07

最新評(píng)論