微服務統一登陸認證怎麼做?JWT ?

来源:https://www.cnblogs.com/zhenghongxin/archive/2018/11/23/10006697.html
-Advertisement-
Play Games

無狀態登錄原理 1.1.什麼是有狀態? 有狀態服務,即服務端需要記錄每次會話的客戶端信息,從而識別客戶端身份,根據用戶身份進行請求的處理,典型的設計如tomcat中的session。 例如登錄:用戶登錄後,我們把登錄者的信息保存在服務端session中,並且給用戶一個cookie值,記錄對應的ses ...


無狀態登錄原理

1.1.什麼是有狀態?

有狀態服務,即服務端需要記錄每次會話的客戶端信息,從而識別客戶端身份,根據用戶身份進行請求的處理,典型的設計如tomcat中的session。

例如登錄:用戶登錄後,我們把登錄者的信息保存在服務端session中,並且給用戶一個cookie值,記錄對應的session。然後下次請求,用戶攜帶cookie值來,我們就能識別到對應session,從而找到用戶的信息。

缺點是什麼?

  • 服務端保存大量數據,增加服務端壓力
  • 服務端保存用戶狀態,無法進行水平擴展
  • 客戶端請求依賴服務端,多次請求必須訪問同一臺伺服器

1.2.什麼是無狀態

微服務集群中的每個服務,對外提供的都是Rest風格的介面。而Rest風格的一個最重要的規範就是:服務的無狀態性,即:

  • 服務端不保存任何客戶端請求者信息
  • 客戶端的每次請求必須具備自描述信息,通過這些信息識別客戶端身份

帶來的好處是什麼呢?

  • 客戶端請求不依賴服務端的信息,任何多次請求不需要必須訪問到同一臺服務
  • 服務端的集群和狀態對客戶端透明
  • 服務端可以任意的遷移和伸縮
  • 減小服務端存儲壓力

1.3.如何實現無狀態

無狀態登錄的流程:

  • 當客戶端第一次請求服務時,服務端對用戶進行信息認證(登錄)
  • 認證通過,將用戶信息進行加密形成token,返回給客戶端,作為登錄憑證
  • 以後每次請求,客戶端都攜帶認證的token
  • 服務端對token進行解密,判斷是否有效。

流程圖:

整個登錄過程中,最關鍵的點是什麼?

token的安全性

token是識別客戶端身份的唯一標示,如果加密不夠嚴密,被人偽造那就完蛋了。

採用何種方式加密才是安全可靠的呢?

我們將採用JWT + RSA非對稱加密

1.4.JWT

1.4.1.簡介

JWT,全稱是Json Web Token, 是JSON風格輕量級的授權和身份認證規範,可實現無狀態、分散式的Web應用授權;官網:https://jwt.io

GitHub上jwt的java客戶端:https://github.com/jwtk/jjwt

1.4.2.數據格式

JWT包含三部分數據:

  • Header:頭部,通常頭部有兩部分信息:

    • 聲明類型,這裡是JWT
    • 加密演算法,自定義

    我們會對頭部進行base64加密(可解密),得到第一部分數據

  • Payload:載荷,就是有效數據,一般包含下麵信息:

    • 用戶身份信息(註意,這裡因為採用base64加密,可解密,因此不要存放敏感信息)
    • 註冊聲明:如token的簽發時間,過期時間,簽發人等

    這部分也會採用base64加密,得到第二部分數據

  • Signature:簽名,是整個數據的認證信息。一般根據前兩步的數據,再加上服務的的密鑰(secret)(不要泄漏,最好周期性更換),通過加密演算法生成。用於驗證整個數據完整和可靠性

生成的數據格式:

可以看到分為3段,每段就是上面的一部分數據

1.4.3.JWT交互流程

流程圖:

步驟翻譯:

  • 1、用戶登錄
  • 2、服務的認證,通過後根據secret生成token
  • 3、將生成的token返回給瀏覽器
  • 4、用戶每次請求攜帶token
  • 5、服務端利用公鑰解讀jwt簽名,判斷簽名有效後,從Payload中獲取用戶信息
  • 6、處理請求,返迴響應結果

因為JWT簽發的token中已經包含了用戶的身份信息,並且每次請求都會攜帶,這樣服務的就無需保存用戶信息,甚至無需去資料庫查詢,完全符合了Rest的無狀態規範。

1.4.4.非對稱加密

加密技術是對信息進行編碼和解碼的技術,編碼是把原來可讀信息(又稱明文)譯成代碼形式(又稱密文),其逆過程就是解碼(解密),加密技術的要點是加密演算法,加密演算法可以分為三類: 

  • 對稱加密,如AES
    • 基本原理:將明文分成N個組,然後使用密鑰對各個組進行加密,形成各自的密文,最後把所有的分組密文進行合併,形成最終的密文。
    • 優勢:演算法公開、計算量小、加密速度快、加密效率高
    • 缺陷:雙方都使用同樣密鑰,安全性得不到保證 
  • 非對稱加密,如RSA
    • 基本原理:同時生成兩把密鑰:私鑰和公鑰,私鑰隱秘保存,公鑰可以下發給信任客戶端
    • 私鑰加密,持有私鑰或公鑰才可以解密
    • 公鑰加密,持有私鑰才可解密
    • 優點:安全,難以破解
    • 缺點:演算法比較耗時
  • 不可逆加密,如MD5,SHA
    • 基本原理:加密過程中不需要使用密鑰,輸入明文後由系統直接經過加密演算法處理成密文,這種加密後的數據是無法被解密的,無法根據密文推算出明文。

RSA演算法歷史:

1977年,三位數學家Rivest、Shamir 和 Adleman 設計了一種演算法,可以實現非對稱加密。這種演算法用他們三個人的名字縮寫:RSA

結合Zuul的鑒權流程

我們逐步演進系統架構設計。需要註意的是:secret是簽名的關鍵,因此一定要保密,我們放到鑒權中心保存,其它任何服務中都不能獲取secret。

1.5.1.沒有RSA加密時

在微服務架構中,我們可以把服務的鑒權操作放到網關中,將未通過鑒權的請求直接攔截,如圖:

  • 1、用戶請求登錄
  • 2、Zuul將請求轉發到授權中心,請求授權
  • 3、授權中心校驗完成,頒發JWT憑證
  • 4、客戶端請求其它功能,攜帶JWT
  • 5、Zuul將jwt交給授權中心校驗,通過後放行
  • 6、用戶請求到達微服務
  • 7、微服務將jwt交給鑒權中心,鑒權同時解析用戶信息
  • 8、鑒權中心返回用戶數據給微服務
  • 9、微服務處理請求,返迴響應

發現什麼問題了?

每次鑒權都需要訪問鑒權中心,系統間的網路請求頻率過高,效率略差,鑒權中心的壓力較大。

結合RSA的鑒權

直接看圖:

  • 我們首先利用RSA生成公鑰和私鑰。私鑰保存在授權中心,公鑰保存在Zuul和各個微服務
  • 用戶請求登錄
  • 授權中心校驗,通過後用私鑰對JWT進行簽名加密
  • 返回jwt給用戶
  • 用戶攜帶JWT訪問
  • Zuul直接通過公鑰解密JWT,進行驗證,驗證通過則放行
  • 請求到達微服務,微服務直接用公鑰解析JWT,獲取用戶信息,無需訪問授權中心

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • HTML<!-- 被註釋的內容 --> CSS/* 被註釋的內容 */ JavaScript單行註釋://被註釋的內容多行註釋:/*被註釋的內容*/ ...
  • 如今,各種互聯網的Web應用程式層出不窮,那麼如何快速入門,成長為一個優秀的Web開發工作者呢? 這個問題不容易回答,幾乎所有的培訓機構都不能清晰地解答。 所以對於Web開發剛剛入門的菜鳥們,我覺得只有通過去做,去實驗,學會Web開發,可能是學著學著,實驗著實驗著就會了。 沒有人告訴你如何去做。我學 ...
  • es6新特性, 提取數組或對象中的值,按照對應位置, 為變數賦值。 交換變數的值變得容易 詳情 點擊這裡 ...
  • git指令總結及常見問題積累與解決方案 git初始化一個項目並且長傳到伺服器後端步驟: 1、本地文件操作 通過:git init初始化化一個項目 會出現一個隱藏文件 ,可以文件夾屬性設置進行查看,此時文件的狀態有三個:原始文件狀態、納入緩存文件狀態、納入版本庫的文件狀態。 原始文件狀態:是文件最初始 ...
  • 在實際開發中,我們經常遇見邊框需要背景漸變的實現要求,那麼如何去實現呢,今天給大家分享依稀幾種情況 1.直角的背景漸變 註意問題:border-image的使用是不能實現圓角的效果,各位需要註意這個屬性 2.圓角的背景漸變 代碼如下:利用偽類元素去實現背景邊的漸變效果,同時我們還可以加上動畫效果,利 ...
  • 今天在認真乾(劃)活(水)的時候,看到群里有人發了一道頭條的面試題,就順便看了一下,發現挺有意思的,就決定分享給大家,並且給出我的解決方案和思考過程。 題目如下: 實現一個get函數,使得下麵的調用可以輸出正確的結果 乍眼一看,這不就是實現一個lodash.get方法嗎?看上去好像很簡單。所以我就開 ...
  • 前端開發過程中,少不了自己封裝一些通用的包,但又不想放在公共的平臺,所以搭建一個npm私有的倉庫是很有必要的。 在這裡簡單介紹如何使用 verdoccio 在docker環境下的配置。verdoccio,輕量級私有npm代理註冊表。加上docker,那就真的無敵方便了,搭建一個私有倉庫輕輕鬆松幾分鐘 ...
  • "策略模式原文地址" "更多《設計模式系列教程》" "更多免費教程" 0. 項目地址 作者按:《每天一個設計模式》旨在初步領會設計模式的精髓,目前採用 ( 靠這吃飯 )和 ( 純粹喜歡 )兩種語言實現。誠然,每種設計模式都有多種實現方式,但此小冊只記錄最直截了當的實現方式 :) "本節課代碼" "《 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...