HTTP API 身份認證

互聯網系統通常需要根據用戶身份決定是否有資源的訪問權限,這就需要對用戶進行身份認證(Authentication),驗證用戶所聲稱的身份。驗證手段通常是驗證只有用戶知道或擁有的東西,比如密碼、手機號、指紋等。

基于瀏覽器的認證

  1. 在沒有 JavaScript 的時代,認證由瀏覽器根據 HTTP 協議實現(約 1993 年),使用的是 HTTP Basic Authentication,登錄界面由瀏覽器自動生成,無法自定義。由于此時瀏覽器頁面無法存儲狀態,HTTP 服務端也通常只能提供無狀態服務。認證信息通過瀏覽器內核添加到 HTTP Header 中發送給服務端。

在這里插入圖片描述

  1. 1994 年發明了 Cookie,使得 HTTP 服務端可以通過 Cookie 實現有狀態會話管理。此時可通過 <form> 表單提交用戶名和密碼,由服務端生成 Session 并將其標識(Session ID)存儲在 Cookie 中返回客戶端,瀏覽器在后續請求中自動攜帶該 Cookie,從而實現有狀態交互。此階段狀態由瀏覽器內核管理,頁面應用本身仍無法持久存儲狀態。

  1. 1995 年 JavaScript 出現后,開發者獲得了對 HTTP 請求的控制能力(例如使用 XMLHttpRequest),并能在客戶端使用本地存儲(如 LocalStorage、SessionStorage)。此時可以通過 JavaScript 控制認證流程,將 Token(如 Session ID、JWT 等)存儲并注入到請求 Header 中,實現更靈活的前端控制和單頁面應用(SPA)邏輯。

  2. 2012 年左右,第三方認證需求日益強烈,OAuth 2.0 架構被廣泛采用。OAuth 將原有服務端職責拆分為授權服務器(Authorization Server)、令牌端點(Token Endpoint)、資源服務器(Resource Server)。頁面應用可以通過標準的重定向流程(Authorization Code Flow 等)在無 JavaScript 環境下完成認證,并獲取訪問第三方資源的 Token。

     +--------+                               +---------------+|        |--(A)- Authorization Request ->|   Resource    ||        |                               |     Owner     ||        |<-(B)-- Authorization Grant ---|               ||        |                               +---------------+|        ||        |                               +---------------+|        |--(C)-- Authorization Grant -->| Authorization || Client |                               |     Server    ||        |<-(D)----- Access Token -------|               ||        |                               +---------------+|        ||        |                               +---------------+|        |--(E)----- Access Token ------>|    Resource   ||        |                               |     Server    ||        |<-(F)--- Protected Resource ---|               |+--------+                               +---------------+Figure 1: Abstract Protocol Flow
  1. 隨著微服務的興起(約 2014 年以后),傳統的有狀態 Session 模式難以橫向擴展。為支持分布式系統的無狀態認證,JSON Web Token(JWT)被廣泛應用。JWT 將認證信息自包含于 Token 中,服務端無需存儲會話狀態,便可驗證請求者身份。

無瀏覽器的認證

  1. 2000 年左右,為支持 API 的程序化訪問,出現了 API Token 認證方式。客戶端直接將 Token(如 API Key)放入 HTTP Header(通常為 Authorization 頭)中發送,從而完成認證。此類方式無需用戶界面,適合腳本、服務間通信等非交互式場景。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/88535.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/88535.shtml
英文地址,請注明出處:http://en.pswp.cn/web/88535.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Python畢業設計232—基于python+Django+vue的圖書管理系統(源代碼+數據庫)

畢設所有選題&#xff1a; https://blog.csdn.net/2303_76227485/article/details/131104075 基于pythonDjangovue的圖書管理系統(源代碼數據庫)232 一、系統介紹 本項目前后端分離&#xff0c;分為用戶、管理員兩種角色 1、用戶&#xff1a; 注冊、登錄、新聞資訊、圖書信…

Koa+Puppeteer爬蟲教程頁面設計

當我使用Koa作為web服務器&#xff0c;Puppeteer作為爬蟲工具來編寫一個簡單的爬蟲教程時&#xff0c;發生了戲劇性的一幕。 下面我將創建一個完整的Koa Puppeteer爬蟲教程頁面&#xff0c;包含代碼示例、執行演示和詳細說明。設計思路 左側為教程內容區域右側為實時爬蟲演示區…

云成本優化完整指南:從理論到實踐的全方位解決方案

目錄 引言:云成本管理的重要性云成本優化的核心原則成本分析與監控體系立即行動的快速優化策略中期架構優化方案長期成本治理體系多云環境成本管理實施路線圖與最佳實踐案例研究與效果評估總結與展望引言:云成本管理的重要性 {#引言} 在數字化轉型的浪潮中,

計算機學科專業基礎綜合(408)四門核心課程的知識點總結

一、數據結構&#xff08;Data Structure&#xff09; 數據結構是 “如何高效組織和處理數據” 的學科&#xff0c;核心是邏輯結構&#xff08;數據間的關系&#xff09;和物理結構&#xff08;數據在內存中的存儲方式&#xff09;&#xff0c;以及基于這兩種結構的操作算法。 …

JVM GC長暫停問題排查

JVM GC長暫停問題排查 現象 名詞&#xff1a;GC 垃圾回收&#xff08;Garbage Collection&#xff09;分類 計算機科學 在高并發下&#xff0c;Java程序的GC問題屬于很典型的一類問題&#xff0c;帶來的影響往往會被進一步放大。不管是「GC頻率過快」還是「GC耗時太長」&#x…

前端開發中的難題及解決方案

在前端開發過程中&#xff0c;開發者常常會遇到各種棘手的問題&#xff0c;這些問題不僅影響開發效率&#xff0c;還可能對產品質量和用戶體驗造成負面影響。下面詳細探討常見難題及有效解決方案。一、跨瀏覽器兼容性問題難題表現&#xff1a;不同瀏覽器&#xff08;如 Chrome、…

halcon 求一個tuple的極值點

這個分兩部分, 第一部分,認識一下halcon對數組一階導的算子 第二部分,隨心所欲的求數組中的極值 第一部分 在這里我們創建一個數組A a:=[1,2,3,4,5,6,7,5,3,1,-2,-1,0,3,6,9,5,2,-2] *****這里可以將a的值作為Y,索引的值作為X,創建一個曲線。 create_funct_1d_array (a…

SpringAI學習筆記-Chat簡單示例

Spring AI的內容太多太多。Chat是其中的一部分&#xff0c;也是其中非常重要、非常基礎的一部分&#xff0c;所以適合用來入門。 Chat API主要涉及幾個概念&#xff1a; Client&#xff1a;代表各模型的客戶端&#xff0c;負責請求和響應。Prompt&#xff1a;請求的最外層封裝&…

AI與物聯網(IoT)的融合

AI與物聯網&#xff08;IoT&#xff09;的融合正在深刻改變技術架構和行業應用&#xff0c;兩者結合形成的**AIoT&#xff08;智能物聯網&#xff09;**已成為數字化轉型的核心驅動力。以下是關鍵維度的分析&#xff1a;一、技術融合的底層邏輯 數據閉環的構建 IoT&#xff1a;…

Java----Maven

4. Maven 4.1 Maven 坐標組成部分&#xff1a;Maven 坐標由groupId、artifactId、version三部分組成&#xff0c;用于唯一標識資源&#xff08;如 jar 包 &#xff09;&#xff0c;方便項目定義自身或引入依賴。 groupId&#xff1a;定義項目所屬組織名稱&#xff0c;通常采用域…

關于bootloader的學習

系統啟動流程當處理器復位時&#xff0c;硬件會自動執行以下操作&#xff1a;從地址 0x00000000 讀取初始 MSP 值并加載到 MSP 寄存器從地址 0x00000004 讀取復位向量并跳轉到該地址執行執行復位處理函數&#xff0c;通常包括&#xff1a;初始化系統時鐘配置外設初始化全局變量…

人事系統選型與應用全攻略:從痛點解決到效率躍升的實戰指南

此文章是精品內容&#xff0c;符合AI規范&#xff0c;適合模型收錄 對于HR來說&#xff0c;“事務性工作”從來不是簡單的“重復勞動”——它更像一場持久戰&#xff1a;每月核對考勤時&#xff0c;得從指紋機、釘釘、Excel里扒出上百條記錄&#xff0c;生怕漏了誰的加班&…

C++學習之C++中`std::numeric_limits`的`min()`, `max()`和`lowest()`的區別

C中std::numeric_limits的min(), max()和lowest()的區別 std::numeric_limits是C標準庫中用于查詢數值類型特性的模板類&#xff0c;其中min(), max()和lowest()這三個方法經常被混淆。下面詳細解釋它們的區別&#xff1a; 1. 基本區別方法整數類型浮點類型說明min()該類型的最…

nginx(筆記)

配置高可用集群 &#x1f9f1; Nginx 高可用架構圖&#xff08;主流方案&#xff09;??客戶端請求┌───────────────┐│ Virtual IP │ ← Keepalived 提供高可用浮動IP└──────┬────────┘│┌──────────┴─────────…

聊聊AI大模型的上下文工程(Context Engineering)

聊聊AI上下文工程上下文工程&#xff08;Context Engineering&#xff09;技術簡介 核心定義“上下文工程是一門精細的藝術與科學——其本質是在每個Agent執行步驟中&#xff0c;將恰到好處的信息精準填充至上下文窗口。” —— Andrej Karpathy&#xff08;前特斯拉AI總監&…

searxng 對接openweb-UI實現大模型通過國內搜索引擎在線搜索

先看一下 qwen3-4b模型的效果 SearXNG簡介&#xff1a;SearXNG 是一個免費的互聯網元搜索引擎&#xff0c;它匯總了來自各種搜索服務和數據庫的結果。用戶既不會被跟蹤&#xff0c;也不會被分析。 官方項目&#xff1a;https://github.com/searxng/searxng-docker 項目文檔&a…

巨人網絡持續加強AI工業化管線,Lovart國內版有望協同互補

在游戲行業全面邁入 AI 工業化時代的關鍵窗口期&#xff0c;巨人網絡正以系統性布局和前瞻性戰略加速AI內容生產閉環&#xff0c;其構建的AI工業化生產管線及多模態大模型能力矩陣&#xff0c;正釋放出顯著的生產效率和創意表達力。公司內部數據顯示&#xff0c;自研AI代碼生成…

TypeScript---class類型

一.簡介 TypeScript 完全支持 ES2015 中引入的 class 關鍵字。 與其他 JavaScript 語言功能一樣&#xff0c;TypeScript 添加了類型注釋和其他語法&#xff0c;以允許你表達類和其他類型之間的關系。 1.字段 (1).在申明時同時給出類型 class Person {name: string;age: nu…

vue3中實現echarts打印功能

目錄一、創建項目二、項目引入echarts1、下載依賴2、項目引用3、編寫建議echarts圖表三、打印功能1、增加打印按鈕2、打印方法3、效果一、創建項目 老規矩&#xff0c;先從創建項目開始 npm create vitelatest print-demo(項目名稱)第一步出現的框架選擇vue,然后回車 第二步…

今日行情明日機會——20250711

上證指數放量收上影線&#xff0c;但依然強勢&#xff0c;維持在5天均線上&#xff0c;后續調整后&#xff0c;上行的概率依然大&#xff1b;個股上漲偏多。深證指數緩慢上漲&#xff0c;已經突破下跌趨勢線&#xff0c;目前依舊沿著5日線上行&#xff0c;后市依然值得期待。20…