摘要:總結總結歸根結底并不是要推翻,而是根據其安全最佳實踐移除不安全的授權流程并且對擴展協議進行整合讓原本復雜如迷宮的規范成為更易用,更安全的授權規范。
2010年, OAuth 授權規范 1.0 (rfc 5849) 版本發布, 2年后, 更簡單易用的 OAuth 2.0 規范發布(rfc 6749), 這也是大家最熟悉并且在互聯網上使用最廣泛的版本, 在2012年的時候, iPhone 5 是全新的, 微軟最新的瀏覽器還是 IE9, 單頁面應用在當時還被稱作 "Ajax 應用", CORS(跨域資源共享)還不是一個W3C標準。
到現在, 網絡和移動領域發生了巨大的變化, 當時發布的授權協議標準已經遠遠不能滿足現在的場景和需求, 為了應對這種不斷變化的局面, OAuth 社區多年來一直在修補和擴展 OAuth 規范, OAuth 的格局也不斷擴大, 越來越多的圍繞 OAuth 2.0 core 的擴展授權規范出現, 也讓 OAuth 2.0 整體看起來就像一個迷宮一樣。
在 OAuth 2.0 核心規范 (RFC 6749)中, 定義了四種授權類型:授權碼、隱式、密碼和客戶端憑據, 如下:
相信大家都很熟悉, 在 OAuth 2.0 中,最安全也是使用最普遍的就是授權碼模式, 而對于本地應用,移動應用來說, 通常會使用隱式和密碼授權, 這兩種本身就是不安全的, 因為這些屬于公開的客戶端, 本身沒有能力保護客戶端機密, 但是當時并沒有其它好的方案。
為了解決 OAuth 2.0 對公開客戶端的授權安全問題, PKCE (RFC 6379)協議應運而生, 全稱是 Proof Key for Code Exchange,PKCE 的原理是, 對于公共的客戶端, 如果不能使用客戶端秘鑰(client_secret), 那客戶端就提供一個自創建的證明 (code_verifier) 給授權服務器,其中使用了加密算法, 授權服務器通過它來驗證客戶端。
后來,"OAuth 2.0 for Native Apps"(RFC 8252)規范發布,推薦原生應用也使用授權碼 + PKCE。
隨著技術不斷地發展, 出現了設備授權的場景, 這里設備指智能電視,打印機等, 和傳統的PC或者手機不同, 這種設備是缺少瀏覽器或者鍵盤的,那 OAuth 2.0 常規的授權模式肯定是不能滿足的, 于是就出現了設備授權(Device Grant) 。
在 OAuth 2.0 安全最佳實踐(Security BCP)中, 棄用了隱式和密碼授權,并且推薦所有的客戶端都應該使用 Authorization Code + PKCE 的組合。
最終, 調整后的 OAuth 授權模式會更加精簡, 轉換成下面三種, 這也是 OAuth 2.1 的思想, 參考安全最佳實踐(BCP),取其精華, 去其糟粕。
歸根結底, OAuth 2.1 并不是要推翻 OAuth 2.0,而是根據其安全最佳實踐(BCP), 移除不安全的授權流程, 并且對擴展協議進行整合, 讓原本復雜如迷宮的 OAuth 2.0 規范成為更易用,更安全的授權規范。
The OAuth 1.0 Protocol
The OAuth 2.0 Authorization Framework
The OAuth 2.1 Authorization Framework draft-ietf-oauth-v2-1-04
Its Time for OAuth 2.1
OAuth 2.0 for Native Apps
OAuth 2.0 Device Authorization Grant
Proof Key for Code Exchange by OAuth Public Clients
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/124545.html
摘要:使用時不應該通過傳遞使用時不應該通過傳遞根據安全最佳實踐章節在使用時您不應該把放到中第一瀏覽器地址欄本來就是暴露的第二可以查看瀏覽記錄,找到。OAuth 2.1 是 OAuth 2.0 的下一個版本, OAuth 2.1 根據最佳安全實踐(BCP), 目前是第18個版本,對 OAuth 2.0 協議進行整合和精簡, 移除不安全的授權流程, 并發布了 OAuth 2.1 規范草案, 下面列出了...
摘要:閉包利用的,其實就是作用域嵌套情況下,內部作用域可以訪問外部作用域這一特性。之所以要將閉包和垃圾回收策略聯系在一起,是因為這涉及到閉包的一些重要特性,如變量暫時存儲和內存泄漏。因為匿名函數回調的閉包實際引用的是變量,而非變量的值。 本文旨在總結在js學習過程中,對閉包的思考,理解,以及一些反思,如有不足,還請大家指教 閉包---closure 閉包是js中比較特殊的一個概念,其特殊之處...
摘要:框架加冕時代年橫空出世的前端框架的模塊機制的模塊機制相比老王老李的解決方案上增強了模塊的約束性,和幫助開發者劃分模塊外,最重要的是解決了模塊的運行時管理問題模塊的初始化順序問題和依賴的模塊自動初始化問題。 前端框架工程化之路 人類的發展動力源于一個懶字,就如現在的大前端正是史前那群懶而聰明的切圖仔進了軟件工程的施工現場,懷揣著更少代碼、更少溝通、更少錯誤、更少維護的夢想奔襲而來。從框架...
閱讀 730·2023-04-25 19:43
閱讀 3974·2021-11-30 14:52
閱讀 3801·2021-11-30 14:52
閱讀 3865·2021-11-29 11:00
閱讀 3796·2021-11-29 11:00
閱讀 3894·2021-11-29 11:00
閱讀 3571·2021-11-29 11:00
閱讀 6154·2021-11-29 11:00