日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁(yè) > 單片機(jī) > 架構(gòu)師社區(qū)
[導(dǎo)讀]1、概述 在存在賬號(hào)體系的信息系統(tǒng)中,對(duì)身份的鑒定是非常重要的事情。 隨著移動(dòng)互聯(lián)網(wǎng)時(shí)代到來(lái),客戶(hù)端的類(lèi)型越來(lái)越多, 逐漸出現(xiàn)了 一個(gè)服務(wù)器,N個(gè)客戶(hù)端的格局 。 不同的客戶(hù)端產(chǎn)生了不同的用戶(hù)使用場(chǎng)景,這些場(chǎng)景: 有不同的環(huán)境安全威脅 不同的會(huì)話(huà)生存


1、概述

在存在賬號(hào)體系的信息系統(tǒng)中,對(duì)身份的鑒定是非常重要的事情。

隨著移動(dòng)互聯(lián)網(wǎng)時(shí)代到來(lái),客戶(hù)端的類(lèi)型越來(lái)越多, 逐漸出現(xiàn)了 一個(gè)服務(wù)器,N個(gè)客戶(hù)端的格局 。

基于 token 的多平臺(tái)身份認(rèn)證架構(gòu)設(shè)計(jì)!

不同的客戶(hù)端產(chǎn)生了不同的用戶(hù)使用場(chǎng)景,這些場(chǎng)景:

  • 有不同的環(huán)境安全威脅

  • 不同的會(huì)話(huà)生存周期

  • 不同的用戶(hù)權(quán)限控制體系

  • 不同級(jí)別的接口調(diào)用方式

綜上所述,它們的身份認(rèn)證方式也存在一定的區(qū)別。

本文將使用一定的篇幅對(duì)這些場(chǎng)景進(jìn)行一些分析和梳理工作。


2、使用場(chǎng)景

下面是一些在IT服務(wù)常見(jiàn)的一些使用場(chǎng)景:

  • 用戶(hù)在web瀏覽器端登錄系統(tǒng),使用系統(tǒng)服務(wù)

  • 用戶(hù)在手機(jī)端(Android/iOS)登錄系統(tǒng),使用系統(tǒng)服務(wù)

  • 用戶(hù)使用開(kāi)放接口登錄系統(tǒng),調(diào)用系統(tǒng)服務(wù)

  • 用戶(hù)在PC處理登錄狀態(tài)時(shí)通過(guò)手機(jī)掃碼授權(quán)手機(jī)登錄(使用得比較少)

  • 用戶(hù)在手機(jī)處理登錄狀態(tài)進(jìn)通過(guò)手機(jī)掃碼授權(quán)PC進(jìn)行登錄(比較常見(jiàn))

通過(guò)對(duì)場(chǎng)景的細(xì)分,得到如下不同的認(rèn)證token類(lèi)別:

1、原始賬號(hào)密碼類(lèi)別

  • 用戶(hù)名和密碼

  • API應(yīng)用ID/KEY

2、會(huì)話(huà)ID類(lèi)別

  • 瀏覽器端token

  • 移動(dòng)端token

  • API應(yīng)用token

3、接口調(diào)用類(lèi)別

  • 接口訪(fǎng)問(wèn)token

  • 身份授權(quán)類(lèi)別

  • PC和移動(dòng)端相互授權(quán)的token


3、token的類(lèi)別

不同場(chǎng)景的token進(jìn)行如下幾個(gè)維度的對(duì)比:

天然屬性對(duì)比:

1、使用成本
本認(rèn)證方式在使用的時(shí)候,造成的不便性。比如:

  • 賬號(hào)密碼需要用戶(hù)打開(kāi)頁(yè)面然后逐個(gè)鍵入

  • 二維碼需要用戶(hù)掏出手機(jī)進(jìn)行掃碼操作

2、變化成本
本認(rèn)證方式,token發(fā)生變化時(shí),用戶(hù)需要做出的相應(yīng)更改的成本:

  • 用戶(hù)名和密碼發(fā)生變化時(shí),用戶(hù)需要額外記憶和重新鍵入新密碼

  • API應(yīng)用ID/KEY發(fā)生變化時(shí),第三方應(yīng)用需要重新在代碼中修改并部署

  • 授權(quán)二維碼發(fā)生變化時(shí),需要用戶(hù)重新打開(kāi)手機(jī)應(yīng)用進(jìn)行掃碼

環(huán)境風(fēng)險(xiǎn)

  • 被偷窺的風(fēng)險(xiǎn)

  • 被抓包的風(fēng)險(xiǎn)

  • 被偽造的風(fēng)險(xiǎn)

可調(diào)控屬性對(duì)比:

1、使用頻率

在網(wǎng)路中傳送的頻率

2、有效時(shí)間

此token從創(chuàng)建到終結(jié)的生存時(shí)間

最終的目標(biāo):安全和影響。

安全和隱私性主要體現(xiàn)在:

  • token 不容易被竊取和盜用(通過(guò)對(duì)傳送頻率控制)

  • token 即使被竊取,產(chǎn)生的影響也是可控的(通過(guò)對(duì)有效時(shí)間控制)

關(guān)于隱私及隱私破壞后的后果,有如下的基本結(jié)論:

  • 曝光頻率高的容易被截獲

  • 生存周期長(zhǎng)的在被截獲后產(chǎn)生的影響更嚴(yán)重和深遠(yuǎn)

遵守如下原則:

  • 變化成本高的token不要輕易變化

  • 不輕易變化的token要減少曝光頻率(網(wǎng)絡(luò)傳輸次數(shù))

  • 曝光頻率高的token的生存周期要盡量短

將各類(lèi)token的固有特點(diǎn)及可控屬性進(jìn)行調(diào)控后, 對(duì)每個(gè)指標(biāo)進(jìn)行量化評(píng)分(1~5分),我們可以得到如下的對(duì)比表:

基于 token 的多平臺(tái)身份認(rèn)證架構(gòu)設(shè)計(jì)!

備注:user_name/passwd 和 app_id/app_key 是等價(jià)的效果


4、token的層級(jí)關(guān)系

參考上一節(jié)的對(duì)比表,可以很容易對(duì)這些不同用途的token進(jìn)行分層,主要可以分為4層:

  • 密碼層:最傳統(tǒng)的用戶(hù)和系統(tǒng)之間約定的數(shù)字身份認(rèn)證方式

  • 會(huì)話(huà)層:用戶(hù)登錄后的會(huì)話(huà)生命周期的會(huì)話(huà)認(rèn)證

  • 調(diào)用層:用戶(hù)在會(huì)話(huà)期間對(duì)應(yīng)用程序接口的調(diào)用認(rèn)證

  • 應(yīng)用層:用戶(hù)獲取了接口訪(fǎng)問(wèn)調(diào)用權(quán)限后的一些場(chǎng)景或者身份認(rèn)證應(yīng)用

token的分層圖如下:

基于 token 的多平臺(tái)身份認(rèn)證架構(gòu)設(shè)計(jì)!

在一個(gè)多客戶(hù)端的信息系統(tǒng)里面,這些token的產(chǎn)生及應(yīng)用的內(nèi)在聯(lián)系如下:

  • 用戶(hù)輸入用戶(hù)名和用戶(hù)口令進(jìn)行一次性認(rèn)證

  • 在 不同 的終端里面生成擁有 不同 生命周期的會(huì)話(huà)token

  • 客戶(hù)端會(huì)話(huà)token從服務(wù)端交換生命周期短但曝光 頻繁 的接口訪(fǎng)問(wèn)token

  • 會(huì)話(huà)token可以生成和刷新延長(zhǎng) access_token 的生存時(shí)間

  • access_token可以生成生存周期最短的用于授權(quán)的二維碼的token

使用如上的架構(gòu)有如下的好處:

  • 良好的統(tǒng)一性。可以解決不同平臺(tái)上認(rèn)證token的生存周期的 歸一化 問(wèn)題

  • 良好的解耦性。核心接口調(diào)用服務(wù)器的認(rèn)證 access_token 可以完成獨(dú)立的實(shí)現(xiàn)和部署

  • 良好的層次性。不同平臺(tái)的可以有完全不同的用戶(hù)權(quán)限控制系統(tǒng),這個(gè)控制可以在 會(huì)話(huà)層 中各平臺(tái)解決掉

4.1、賬號(hào)密碼

廣義的 賬號(hào)/密碼 有如下的呈現(xiàn)方式:

  • 傳統(tǒng)的注冊(cè)用戶(hù)名和密碼

  • 應(yīng)用程序的app_id/app_key

它們的特點(diǎn)如下:

1、會(huì)有特別的意義

比如:用戶(hù)自己為了方便記憶,會(huì)設(shè)置有一定含義的賬號(hào)和密碼。

2、不常修改

賬號(hào)密碼對(duì)用戶(hù)有特別含義,一般沒(méi)有特殊情況不會(huì)愿意修改。而app_id/app_key則會(huì)寫(xiě)在應(yīng)用程序中,修改會(huì)意味著重新發(fā)布上線(xiàn)的成本

3、一旦泄露影響深遠(yuǎn)

正因?yàn)椴怀P薷?,只要泄露了基本相?dāng)于用戶(hù)的網(wǎng)絡(luò)身份被泄露,而且只要沒(méi)被察覺(jué)這種身份盜用就會(huì)一直存在

所以在認(rèn)證系統(tǒng)中應(yīng)該盡量減少傳輸?shù)臋C(jī)會(huì),避免泄露。

4.2、客戶(hù)端會(huì)話(huà)token

功能:

充當(dāng)著session的角色,不同的客戶(hù)端有不同的生命周期。

使用步驟:

用戶(hù)使用賬號(hào)密碼,換取會(huì)話(huà)token

不同的平臺(tái)的token有不同的特點(diǎn):

Web平臺(tái)生存周期短

主要原因:

  • 環(huán)境安全性:由于web登錄環(huán)境一般很可能是公共環(huán)境,被他人盜取的風(fēng)險(xiǎn)值較大

  • 輸入便捷性:在PC上使用鍵盤(pán)輸入會(huì)比較便捷

移動(dòng)端生存周期長(zhǎng)

主要原因:

  • 環(huán)境安全性:移動(dòng)端平臺(tái)是個(gè)人用戶(hù)極其私密的平臺(tái),它人接觸的機(jī)會(huì)不大

  • 輸入便捷性:在移動(dòng)端上使用手指在小屏幕上觸摸輸入體驗(yàn)差,輸入成本高

4.3、access_token

功能:

服務(wù)端應(yīng)用程序api接口訪(fǎng)問(wèn)和調(diào)用的憑證。

使用步驟:

使用具有較長(zhǎng)生命周期的會(huì)話(huà)token來(lái)?yè)Q取此接口訪(fǎng)問(wèn)token。

其曝光頻率直接和接口調(diào)用頻率有關(guān),屬于高頻使用的憑證。為了照顧到隱私性,盡量減少其生命周期,即使被截取了,也不至于產(chǎn)生嚴(yán)重的后果。

注意:在客戶(hù)端token之下還加上一個(gè)access_token, 主要是為了讓具有不同生命周期的客戶(hù)端token最后在調(diào)用api的時(shí)候, 能夠具有統(tǒng)一的認(rèn)證方式。

4.4、pam_token

功能:

由已經(jīng)登錄和認(rèn)證的PC端生成的二維碼的原始串號(hào)(Pc Auth Mobile)。

主要步驟如下:

  1. PC上用戶(hù)已經(jīng)完成認(rèn)證,登錄了系統(tǒng)

  2. PC端生成一組和此用戶(hù)相關(guān)聯(lián)的pam_token

  3. PC端將此pam_token的使用鏈接生成二維碼

  4. 移動(dòng)端掃碼后,請(qǐng)求服務(wù)器,并和用戶(hù)信息關(guān)聯(lián)

  5. 移動(dòng)端獲取refresh_token(長(zhǎng)時(shí)效的會(huì)話(huà))

  6. 根據(jù) refresh_token 獲取 access_token

  7. 完成正常的接口調(diào)用工作


備注:

  • 生存周期為2分鐘,2分鐘后過(guò)期刪除

  • 沒(méi)有被使用時(shí),每1分鐘變一次

  • 被使用后,立刻刪除掉

  • 此種認(rèn)證模式一般不會(huì)被使用到

4.5、map_token

功能:

由已經(jīng)登錄的移動(dòng)app來(lái)掃碼認(rèn)證PC端系統(tǒng),并完成PC端系統(tǒng)的登錄(Mobile Auth Pc)。

主要步驟:

  1. 移動(dòng)端完成用戶(hù)身份的認(rèn)證登錄app

  2. 未登錄的PC生成匿名的 map_token

  3. 移動(dòng)端掃碼后在db中生成 map_token 和用戶(hù)關(guān)聯(lián)(完成簽名)

  4. db同時(shí)針對(duì)此用戶(hù)生成 web_token

  5. PC端一直以 map_token 為參數(shù)查找此命名用戶(hù)的 web_token

  6. PC端根據(jù) web_token 去獲取 access_token

  7. 后續(xù)正常的調(diào)用接口調(diào)用工作

備注:

  • 生存周期為2分鐘,2分鐘后過(guò)期刪除

  • 沒(méi)有被使用時(shí),每1分鐘變一次

  • 被使用后,立刻刪除掉


5、小結(jié)與展望

本文所設(shè)計(jì)的基于token的身份認(rèn)證系統(tǒng),主要解決了如下的問(wèn)題:

  • token的分類(lèi)問(wèn)題

  • token的隱私性參數(shù)設(shè)置問(wèn)題

  • token的使用場(chǎng)景問(wèn)題

  • 不同生命周期的token分層轉(zhuǎn)化關(guān)系

本文中提到的設(shè)計(jì)方法,在 應(yīng)用層 中可以適用于且不限于如下場(chǎng)景中:

  • 用戶(hù)登錄

  • 有時(shí)效的優(yōu)惠券發(fā)放

  • 有時(shí)效的邀請(qǐng)碼發(fā)放

  • 有時(shí)效的二維碼授權(quán)

  • 具有時(shí)效 手機(jī)/郵件 驗(yàn)證碼

  • 多個(gè)不同平臺(tái)調(diào)用同一套API接口

  • 多個(gè)平臺(tái)使用同一個(gè)身份認(rèn)證中心

至于更多的使用場(chǎng)景,就需要大家去發(fā)掘了。

END

作者:哈莫 ,本文版權(quán)歸作者所有

cnblogs.com/beer/p/6029861.html


特別推薦一個(gè)分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒(méi)關(guān)注的小伙伴,可以長(zhǎng)按關(guān)注一下:

基于 token 的多平臺(tái)身份認(rèn)證架構(gòu)設(shè)計(jì)!

基于 token 的多平臺(tái)身份認(rèn)證架構(gòu)設(shè)計(jì)!

基于 token 的多平臺(tái)身份認(rèn)證架構(gòu)設(shè)計(jì)!

長(zhǎng)按訂閱更多精彩▼

基于 token 的多平臺(tái)身份認(rèn)證架構(gòu)設(shè)計(jì)!

如有收獲,點(diǎn)個(gè)在看,誠(chéng)摯感謝



免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺(tái)僅提供信息存儲(chǔ)服務(wù)。文章僅代表作者個(gè)人觀點(diǎn),不代表本平臺(tái)立場(chǎng),如有問(wèn)題,請(qǐng)聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專(zhuān)欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動(dòng)電源

在工業(yè)自動(dòng)化蓬勃發(fā)展的當(dāng)下,工業(yè)電機(jī)作為核心動(dòng)力設(shè)備,其驅(qū)動(dòng)電源的性能直接關(guān)系到整個(gè)系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動(dòng)勢(shì)抑制與過(guò)流保護(hù)是驅(qū)動(dòng)電源設(shè)計(jì)中至關(guān)重要的兩個(gè)環(huán)節(jié),集成化方案的設(shè)計(jì)成為提升電機(jī)驅(qū)動(dòng)性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機(jī) 驅(qū)動(dòng)電源

LED 驅(qū)動(dòng)電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個(gè)照明設(shè)備的使用壽命。然而,在實(shí)際應(yīng)用中,LED 驅(qū)動(dòng)電源易損壞的問(wèn)題卻十分常見(jiàn),不僅增加了維護(hù)成本,還影響了用戶(hù)體驗(yàn)。要解決這一問(wèn)題,需從設(shè)計(jì)、生...

關(guān)鍵字: 驅(qū)動(dòng)電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動(dòng)電源的公式,電感內(nèi)電流波動(dòng)大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設(shè)計(jì) 驅(qū)動(dòng)電源

電動(dòng)汽車(chē)(EV)作為新能源汽車(chē)的重要代表,正逐漸成為全球汽車(chē)產(chǎn)業(yè)的重要發(fā)展方向。電動(dòng)汽車(chē)的核心技術(shù)之一是電機(jī)驅(qū)動(dòng)控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機(jī)驅(qū)動(dòng)系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動(dòng)汽車(chē)的動(dòng)力性能和...

關(guān)鍵字: 電動(dòng)汽車(chē) 新能源 驅(qū)動(dòng)電源

在現(xiàn)代城市建設(shè)中,街道及停車(chē)場(chǎng)照明作為基礎(chǔ)設(shè)施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進(jìn)步,高亮度白光發(fā)光二極管(LED)因其獨(dú)特的優(yōu)勢(shì)逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動(dòng)電源 LED

LED通用照明設(shè)計(jì)工程師會(huì)遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動(dòng)電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動(dòng)電源的電磁干擾(EMI)問(wèn)題成為了一個(gè)不可忽視的挑戰(zhàn)。電磁干擾不僅會(huì)影響LED燈具的正常工作,還可能對(duì)周?chē)娮釉O(shè)備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來(lái)解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動(dòng)電源

開(kāi)關(guān)電源具有效率高的特性,而且開(kāi)關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機(jī)重量也有所下降,所以,現(xiàn)在的LED驅(qū)動(dòng)電源

關(guān)鍵字: LED 驅(qū)動(dòng)電源 開(kāi)關(guān)電源

LED驅(qū)動(dòng)電源是把電源供應(yīng)轉(zhuǎn)換為特定的電壓電流以驅(qū)動(dòng)LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動(dòng)電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動(dòng)電源
關(guān)閉