云智慧(北京)科技有限公司鄧超
安陽ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)建站的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!
說起oauth3.0,我相信很多人對其已經(jīng)非常熟悉,并且已經(jīng)應用在很多開放平臺上,如新浪微博開放平臺,騰訊微博開放平臺等;下面我將我個人對于Oauth3的理解以及Oauth3在監(jiān)控寶開放平臺上的是如何運用的做一下簡單的闡述,有說的不到位的地方還望指點。
官方定義:
OAuth(開放授權(quán))是一個開放標準,允許用戶讓第三方應用訪問該用戶在某一網(wǎng)站上存儲的私密的資源,而無需將用戶名和密碼提供給第三方應用。
OAuth允許用戶提供一個令牌,而不是用戶名和密碼來訪問他們存放在特定服務提供者的數(shù)據(jù)。每一個令牌授權(quán)一個特定的網(wǎng)站在特定的時段內(nèi)訪問特定的資源。這樣,OAuth讓用戶可以授權(quán)第三方網(wǎng)站訪問他們存儲在另外服務提供者的某些特定信息,而非所有內(nèi)容。
OAuth 2.0是OAuth協(xié)議的下一版本,但不向下兼容OAuth 1.0。OAuth 2.0關(guān)注客戶端開發(fā)者的簡易性,同時為Web應用,桌面應用和手機,和起居室設(shè)備提供專門的認證流程。
個人理解:
Oauth3.0就是一個互聯(lián)網(wǎng)標準協(xié)議(基于https) ,可以讓用戶來實現(xiàn)跨平臺數(shù)據(jù)共享。
比如有2個平臺A和B,在A平臺上有一些數(shù)據(jù)資源,現(xiàn)在B平臺想拿到A平臺上的某些數(shù)據(jù)資源,如果此時A平臺支持Oauth3協(xié)議,那么B平臺就可以通過協(xié)議向A平臺請求相應的數(shù)據(jù)資源應用的B平臺上。
OAuth在"客戶端"與"資源服務端"之間,設(shè)置了一個授權(quán)層(authorization layer)。其過程如圖(來自RFC 6749 ):
(A)“客戶端”向“資源所屬者”發(fā)出授權(quán)請求
(B)“資源所屬者”同意給“客戶端”授權(quán)
(C)“客戶端”獲得授權(quán)后向“認證服務端”請求令牌
(D)“認證服務端”向“客戶端”發(fā)放令牌(Access Token)
(E)“客戶端”通過令牌向“資源服務端”請求資源
(F)“資源服務端”確認令牌無誤,向“客戶端”發(fā)放資源
從以上步驟可以看出,“客戶端”想拿到資源,關(guān)鍵點在于“資源所屬者”的授權(quán),只有拿到了授權(quán),才可以進行接下來的步驟。
OAuth 2.0定義了四種授權(quán)方式:
§ A、授權(quán)碼模式(authorization code)
授權(quán)碼模式(authorization code)的特點就是通過客戶端的后臺 § B、簡化模式(implicit) 簡化模式(implicit grant type)不通過第三方應用程序的服務器,直接在 瀏覽器中向認證服務器申請令牌,跳過了"授權(quán)碼"這個步驟。所有步驟在瀏覽器中 完成,令牌對訪問者是可見的,且客戶端不需要認證。 § C、密碼模式(resource owner passwordcredentials) 密碼模式(Resource Owner Password Credentials Grant)中,用戶向 客戶端提供自己的用戶名和密碼??蛻舳耸褂眠@些信息,向"服務商提供商"索要授 權(quán)。 § D、客戶端模式(client credentials 客戶端模式(Client Credentials Grant)指客戶端以自己的名義,而不是 以用戶的名義,向"服務提供商"進行認證。 § 目前監(jiān)控寶的API平臺只對監(jiān)控寶企業(yè)用戶開發(fā),而不對所有監(jiān)控寶用戶開發(fā)?;谶@種情況,Oauth的密碼授權(quán)模式比較適合(注:通過賬號和密碼,平臺就可以認證是否為監(jiān)控寶企業(yè)用戶,從而來判斷是否給予授權(quán)),所以我們果斷采用了這種授權(quán)方式。 監(jiān)控寶API平臺簡化了授權(quán)過程,平臺將每一個企業(yè)賬號當做一個客戶端,并自動為其生成一個唯一的授權(quán)標識,所以每一個客戶端可以直接向平臺認證服務端請求令牌,然后通過令牌向平臺資源服務端請求資源。如圖(監(jiān)控寶API平臺認證過程): 關(guān)于監(jiān)控寶API平臺請具體參考: http://www.jiankongbao.com/common/api_interface 關(guān)于作者: 鄧超,云智慧軟件開發(fā)工程師,2010年畢業(yè)于秦皇島燕山大學,2012年初加入云智慧(北京)科技有限公司。目前主要負責監(jiān)控寶產(chǎn)品架構(gòu)的優(yōu)化與研發(fā)。
本文名稱:oauth2.0在監(jiān)控寶項目中的應用一例
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營銷、品牌網(wǎng)站建設(shè)、ChatGPT、微信小程序、網(wǎng)站改版、Google
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源:
創(chuàng)新互聯(lián)
四、Oauth3在監(jiān)控寶API平臺上的運用
網(wǎng)址分享:http://jinyejixie.com/article48/pochep.html