」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 了解身分驗證流程

了解身分驗證流程

發佈於2024-11-07
瀏覽:830

Understanding the Authentication Flow

什麼是身分驗證流程?

身分驗證流程是確認使用者身分並管理他們對應用程式某些部分的存取的過程。當您使用網路應用程式(例如社交媒體網站)時,這涉及檢查使用者是否是他們所說的人(登入),然後授予他們存取某些功能的權限。

它在 React 中是如何運作的?

在 React 中,當您想要處理使用者驗證時,通常會與處理繁重工作的後端伺服器進行互動。它通常是這樣運作的:

1. 註冊與登入端點

  • 註冊端點:當新用戶註冊時,他們會將其詳細資訊(如使用者名稱、電子郵件、密碼)發送到伺服器。然後伺服器為他們創建一個帳戶。
  • 登入端點:現有使用者登入時,會將其使用者名稱和密碼傳送至伺服器。伺服器檢查這些詳細資訊是否正確。

2. 令牌:存取令牌和刷新令牌

登入成功後,伺服器返回兩個重要的token:

  • 存取權杖:

    • 這就像一個短期通行證,允許用戶訪問應用程式的某些功能。它的壽命通常很短(在本例中為 5 分鐘)。
    • 每次使用者發出請求(例如查看他們的個人資料或發布某些內容)時,此令牌都會發送到伺服器以證明他們已登入。
  • 刷新代幣:

    • 這就像是存取令牌過期時使用的備份通行證。更持久。
    • 當存取權杖過期(5分鐘後)時,應用程式可以使用刷新令牌來取得新的存取令牌,而不是讓使用者再次登入。

3. 在瀏覽器中儲存令牌

用戶登入並收到這些代幣後,應用程式需要將它們儲存在用戶裝置上的某個位置。這就是 localStorage 的用武之地:

  • localStorage: 這是網頁瀏覽器中的一項功能,可讓您在使用者的瀏覽器中儲存資料(如代幣)。
    • setItem() 方法: 用於儲存資料。例如,您可以使用 localStorage.setItem('accessToken', tokenValue).
    • 之類的內容儲存存取令牌和刷新令牌
    • getItem() 方法: 用於擷取儲存的資料。例如,您可以使用 localStorage.getItem('accessToken').
    • 等方式取得儲存的存取令牌

4. 使用存取權杖發出請求

每次使用者執行需要伺服器互動的操作(例如發布狀態或檢視訊息)時,應用程式都會向伺服器發送請求,並在授權標頭中附加存取權杖。這告訴伺服器使用者已登入並允許執行該操作。

5. 處理過期令牌

  • 存取權杖過期: 如果伺服器回應 401 錯誤,則表示存取權杖已過期。然後,應用程式將使用刷新令牌來請求新的存取權杖。

  • 刷新令牌過期:如果刷新令牌也過期了(這可能會在很長一段時間後發生),伺服器將再次回應 401 錯誤。此時,應用程式會將使用者重新導向到登入頁面,要求他們再次登入以取得新令牌。

6. 重新發送失敗的請求

一旦應用程式使用刷新令牌來獲取新的存取令牌,它將重新發送因令牌過期而失敗的原始請求。這樣,用戶就不會遇到任何中斷。

概括

  • 身分驗證流程:這是應用程式確認您是誰並為您提供功能存取權限的方式。
  • 存取權杖:存取應用程式中資源的短期金鑰。很快就會過期。
  • 刷新令牌: 長期備份金鑰,用於在舊存取權杖過期時取得新的存取權杖。
  • localStorage: 瀏覽器在使用者裝置上儲存這些代幣的方式。
  • 授權標頭: 存取權杖包含在對伺服器的請求中。
  • 401 錯誤: 令牌已過期且應用程式需要採取操作(刷新令牌或要求使用者重新登入)的訊號。

此流程可確保使用者可以保持登入狀態並安全地使用應用程序,而無需始終重新輸入其憑證。

版本聲明 本文轉載於:https://dev.to/vincod/understanding-the-authentication-flow-3ndk?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • Floyd 演算法如何偵測鍊錶中的迴圈?
    Floyd 演算法如何偵測鍊錶中的迴圈?
    使用 Floyd 演算法檢測鍊錶中的循環確定給定鍊錶是否包含循環在 Java 程式設計中是一項具有挑戰性的任務。當清單中的最後一個節點引用前一個節點而不是空引用時,就會發生循環。 為了有效地偵測循環,開發人員通常採用 Floyd 的循環查找演算法,也稱為龜兔賽跑演算法。該演算法使用兩個引用,一個慢速...
    程式設計 發佈於2024-11-07
  • 如何在不使用 Flash 的情況下使用 JavaScript 在客戶端調整圖像大小?
    如何在不使用 Flash 的情況下使用 JavaScript 在客戶端調整圖像大小?
    使用JavaScript 在客戶端調整圖像大小:開源解決方案在當今的Web 開發環境中,通常需要在客戶端調整圖像大小之前將它們上傳到伺服器。這種方法可以優化影像質量,減少伺服器負載,並透過加快頁面載入時間來改善使用者體驗。 雖然 Flash 是調整圖片大小的常見選項,但許多開發人員寧願避免使用它。幸...
    程式設計 發佈於2024-11-07
  • 通訊:數據獲取模式
    通訊:數據獲取模式
    重大公告! 我開始了我日常的前端系統設計學習之旅。我將在部落格中分享每個模組的見解。所以,這就是開始,還有更多精彩! 在本部落格中,我們將探討前端系統設計所必需的不同資料取得機制,包括短輪詢、長輪詢、WebSocket、伺服器發送事件 (SSE) 和 Webhook。每種技術都滿足向客戶端和伺服...
    程式設計 發佈於2024-11-07
  • #daysofMiva 編碼挑戰日:將 JavaScript 連結到 HTML 檔案。
    #daysofMiva 編碼挑戰日:將 JavaScript 連結到 HTML 檔案。
    嗨,大家好。很抱歉這篇文章遲發了,但遲發總比不發好?無論如何,讓我們深入了解今天的文章。 為什麼要將 Javascript 連結到 HTML 檔案。 JavaScript 是一種在瀏覽器中運行的程式語言,可以操縱網頁的內容、結構和樣式。透過將 JavaScript 檔案連結到 HT...
    程式設計 發佈於2024-11-07
  • 為什麼我的 canvas.toDataURL() 沒有儲存我的圖像?
    為什麼我的 canvas.toDataURL() 沒有儲存我的圖像?
    Resolving Image Saving Issues with canvas.toDataURL()When attempting to utilize canvas.toDataURL() to save&&]When attempting to utilize canvas.toDataU...
    程式設計 發佈於2024-11-07
  • Node.js 中的新增功能
    Node.js 中的新增功能
    TL;DR: 让我们探索 Node.js 22 的主要功能,包括 ECMAScript 模块支持和 V8 引擎更新。此版本引入了 Maglev 编译器和内置 WebSocket 客户端,以增强性能和实时通信。还涵盖了测试、调试和文件系统管理方面的改进。 Node.js 22 将于 10 月进入 LT...
    程式設計 發佈於2024-11-07
  • 了解 MongoDB 的distinct() 操作:實用指南
    了解 MongoDB 的distinct() 操作:實用指南
    MongoDB 的distinct() 操作是一個強大的工具,用於從集合中的指定欄位檢索唯一值。本指南將幫助您了解distinct() 的用途、使用它的原因和時間,以及如何在 MongoDB 查詢中有效地實現它。 什麼是distinct()? distinct() 方法傳回集合或集...
    程式設計 發佈於2024-11-07
  • 為什麼 JavaScript 中的「0」在比較中為 False,而在「if」語句中為 True?
    為什麼 JavaScript 中的「0」在比較中為 False,而在「if」語句中為 True?
    揭開JavaScript 的悖論:為什麼「0」在比較中為假,但在If 語句中為假在JavaScript中,原語" 的行為0」給開發者帶來了困惑。雖然諸如“==”之類的邏輯運算符將“0”等同於假,但“0”在“if”條件下表現為真。 比較悖論代碼下面演示了比較悖論:"0" ...
    程式設計 發佈於2024-11-07
  • GitHub Copilot 有其怪癖
    GitHub Copilot 有其怪癖
    過去 4 個月我一直在將 GitHub Copilot 與我們的生產代碼庫一起使用,以下是我的一些想法: 好的: 解釋複雜程式碼:它非常適合分解棘手的程式碼片段或商業邏輯並正確解釋它們。 單元測試:非常擅長編寫單元測試並快速產生多個基於場景的測試案例。 程式碼片段:它可以輕鬆地為通用用例產生有用...
    程式設計 發佈於2024-11-07
  • 靜態類別或實例化類別:什麼時候應該選擇哪一個?
    靜態類別或實例化類別:什麼時候應該選擇哪一個?
    在靜態類別和實例化類別之間做出選擇:概述在PHP 中設計軟體應用程式時,開發人員經常面臨在使用靜態類別或實例化物件。這個決定可能會對程式的結構、效能和可測試性產生重大影響。 何時使用靜態類別靜態類別適用於物件不具備靜態類別的場景獨特的數據,只需要存取共享功能。例如,用於將 BB 程式碼轉換為 HTM...
    程式設計 發佈於2024-11-07
  • ⚠️ 在 JavaScript 中使用 `var` 的隱藏危險:為什麼是時候繼續前進了
    ⚠️ 在 JavaScript 中使用 `var` 的隱藏危險:為什麼是時候繼續前進了
    关键字 var 多年来一直是 JavaScript 中声明变量的默认方式。但是,它有一些怪癖和陷阱,可能会导致代码出现意外行为。现代替代方案(如 let 和 const)解决了许多此类问题,使它们成为大多数情况下声明变量的首选。 1️⃣ 提升:var 在不知不觉中声明变量! ?解释:...
    程式設計 發佈於2024-11-07
  • PDO::MYSQL_ATTR_INIT_COMMAND 需要「SET CHARACTER SET utf8」嗎?
    PDO::MYSQL_ATTR_INIT_COMMAND 需要「SET CHARACTER SET utf8」嗎?
    在有「PDO::MYSQL_ATTR_INIT_COMMAND」的 PDO 中「SET CHARACTER SET utf8」是否必要? 在PHP 和MySQL 中,「SET NAMES」 utf8」和「SET CHARACTER SET utf8」通常在使用UTF-8 編碼時使用。但是,當使用PD...
    程式設計 發佈於2024-11-07
  • 為什麼使用Password_Hash函數時哈希值會改變?
    為什麼使用Password_Hash函數時哈希值會改變?
    了解Password_Hash函數中不同的雜湊值在開發安全認證系統時,開發人員經常會遇到使用password_hash取得不同密碼哈希值的困惑功能。為了闡明此行為並確保正確的密碼驗證,讓我們分析此函數背後的機制。 密碼加鹽:有意的功能password_hash 函數有意產生唯一的鹽它對每個密碼進行哈...
    程式設計 發佈於2024-11-07
  • 為什麼與谷歌競爭並不瘋狂
    為什麼與谷歌競爭並不瘋狂
    大家好,我是 Antonio,Litlyx 的首席執行官,我們的對手是一些巨頭! Microsoft Clarity、Google Analytics、MixPanel...它們是分析領域的重要參與者。當人們聽到一家新創公司正在與如此知名的公司合作時,他們常常會感到驚訝。但讓我們看看為什麼與Goo...
    程式設計 發佈於2024-11-07
  • 如何在 Java Streams 中有效地將物件清單轉換為可選物件?
    如何在 Java Streams 中有效地將物件清單轉換為可選物件?
    使用Java 8 的可選和Stream::flatMap 變得簡潔使用Java 8 流時,將List 轉換為可選 並有效地提取第一個Other 值可能是一個挑戰。雖然 flatMap 通常需要返回流,但可選的 Stream() 的缺失使問題變得複雜。 Java 16 解決方案Java 16 引入了S...
    程式設計 發佈於2024-11-07

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3