在Thinkphp中使用JWT 包括JWT是什么,JWT的優勢

首先了解一下什么是JWT

JWT 是一種開放標準(RFC 7519),用于在各方之間以 JSON 對象形式安全傳輸信息4。其核心特點包括:

結構:由三部分組成(Header、Payload、Signature),通過點號分隔,例如 xxxxx.yyyyy.zzzzz2。Header:聲明加密算法和 Token 類型(如 HS256)。Payload:包含用戶信息、注冊聲明(如 iss、exp)和自定義數據。Signature:通過密鑰對前兩部分簽名,確保數據完整性。
用途:身份認證:用戶登錄后,服務端生成 JWT 返回客戶端,客戶端后續請求攜帶 JWT 以訪問受保護資源1。

JWT的優勢

  1. 無狀態性

    優勢:JWT 自身包含用戶身份和權限信息,服務端無需存儲會話數據(如 Session),直接通過驗證 Token 簽名即可完成認證。
    效果:降低服務端資源消耗,天然支持分布式系統和橫向擴展。
    對比:傳統 Session 需要服務端維護會話狀態,多服務器場景需共享 Session 存儲(如 Redis),增加復雜度。
    
  2. 跨域支持

    優勢:JWT 通過 HTTP 頭(如 Authorization: Bearer <token>)傳遞,不受 Cookie 同源策略限制。
    應用場景:適合前后端分離、跨域 API 調用及微服務架構。
    對比:Cookie 需額外配置 CORS 策略,且存在跨域限制。
    
  3. 安全性增強

    優勢:防 CSRF:Token 存儲在客戶端而非 Cookie,避免跨站請求偽造攻擊。
    防篡改:簽名機制(如 HS256)確保 Token 內容完整性和來源可信。
    
  4. 標準化與靈活性

    優勢:JWT 遵循 RFC 7519 標準,支持多種簽名算法(如 RSA、HMAC)和自定義聲明(Claims),便于集成第三方服務。
    擴展場景:單點登錄(SSO)、API 網關鑒權等。
    

搭建JWT工具類

首先確定一些參數

private static $key = '4875c029de194dd79ade2ee5aa68ee57';//密鑰
private const exp = 3600;//token過期時間 1小時
private const alg = 'HS256';//加密算法
private const iss = 'ceshi';// 簽發人
private const aud = 'web';// 受眾   

密鑰可以自己隨便寫,但是建議不要太簡單
簽發人一般是用于校驗該token是不是自己的
受眾一般是用于區分web和app端的

密鑰可以使用下面代碼生成一個

public function init()
{$md5 = md5(time());return $md5;
}

生成密鑰的方法

public static function createToken($data)
{$time = time();$payload = ["iat" => $time, // 簽發時間"nbf" => $time, // 生效時間"exp" => self::exp + $time, // 失效時間"iss" => self::iss,// 簽發人"aud" => self::aud,// 受眾"data" => $data, // 自定義數據];return JWT::encode($payload, self::$key, self::alg);
}

使用樣例

$token = Token::createToken(['id' => '1', 'role' => 'admin']);

解析密鑰并校驗的方法

解析方法
private static function decodeToken($token)
{try {return JWT::decode($token, new Key(self::$key, self::alg));} catch (\Exception $e) {throw new HttpResponseException(json(['code' => 401, 'msg' => 'token無效']));}
}
驗證管理員
public static function isAdmin($token)
{$decodeToken = self::decodeToken($token);return $decodeToken->data->role === 'admin';
}

使用樣例

if (!Token::isAdmin($token)) {$this->error('權限不足');
}
驗證是否為本人token
public static function checkSelf($userId, $token)
{$decodeToken = self::decodeToken($token);return $decodeToken->data->id == $userId;}

使用樣例

if (!Token::checkSelf($id, $token)) {$this->error('權限不足');
}
完整代碼
<?phpnamespace app\common\library;//這個命名空間記得要換成自己的use Firebase\JWT\JWT;
use Firebase\JWT\Key;
use think\exception\HttpResponseException;class Token
{private static $key = '4875c029de194dd79ade2ee5aa68ee57';//密鑰private const exp = 3600;//token過期時間 1小時private const alg = 'HS256';//加密算法private const iss = 'ceshi';// 簽發人private const aud = 'web';// 受眾public static function createToken($data){$time = time();$payload = ["iat" => $time, // 簽發時間"nbf" => $time, // 生效時間"exp" => self::exp + $time, // 失效時間"iss" => self::iss,// 簽發人"aud" => self::aud,// 受眾"data" => $data, // 自定義數據];return JWT::encode($payload, self::$key, self::alg);}public static function isAdmin($token){$decodeToken = self::decodeToken($token);return $decodeToken->data->role === 'admin';}public static function checkSelf($userId, $token){$decodeToken = self::decodeToken($token);return $decodeToken->data->id == $userId;}private static function decodeToken($token){try {return JWT::decode($token, new Key(self::$key, self::alg));} catch (\Exception $e) {throw new HttpResponseException(json(['code' => 401, 'msg' => 'token無效']));}}}

使用JWT需要額外安裝擴展

composer require firebase/php-jwt

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

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

相關文章

hackmyvn-casino

arp-scan -l nmap -sS -v 192.168.255.205 目錄掃描 dirsearch -u http://192.168.255.205/ -e * gobuster dir -u http://192.168.255.205 -w /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt -x php -b 301,401,403,404 80端口 隨便注冊一個賬號 玩游戲時的…

圖表配置表增加分析指標字段

在設計報表圖表配置表時&#xff0c;為存儲 同比、環比 這類分析指標&#xff0c;建議通過以下方式定義字段結構和命名&#xff1a; 一、字段設計方案 // 配置表示例結構 interface ChartConfig {id: string; // 唯一標識name: string; // 圖表…

廣州SMT貼片加工廠精密制造工藝解析

內容概要 在電子制造領域&#xff0c;SMT貼片加工技術已成為現代電子產品精密組裝的核心環節。廣州作為華南地區電子產業的重要樞紐&#xff0c;其SMT貼片加工廠通過融合自動化設備與嚴格工藝標準&#xff0c;構建起高效可靠的制造體系。 對于電子產品制造商而言&#xff0c;…

RK3568-適配ov5647攝像頭

硬件原理圖 CAM_GPIO是攝像頭電源控制引腳,連接芯片GPIO4_C2 CAM_LEDON是攝像頭led燈控制引腳,連接芯片GPIO4_C3編寫設備樹 / {ext_cam_clk: external-camera-clock {compatible = "fixed-clock";clock-frequency = <25000000>;clock-output-names = "…

關于 @Autowired 和 @Value 使用 private 字段的警告問題分析與解決方案

問題背景 在使用 Spring 框架進行開發時&#xff0c;我們經常會使用 Autowired 和 Value 注解來進行依賴注入和屬性值注入。然而&#xff0c;當我們將這些注解應用于 private 字段時&#xff0c;IDE&#xff08;如 IntelliJ IDEA&#xff09;可能會顯示警告信息&#xff0c;提…

Flutter 開發環境配置--宇宙級教學!

目錄 一、安裝環境&#xff08;Windows&#xff09;二、Android 創建Flutter項目三、VSCode 搭建環境四、補充 一、安裝環境&#xff08;Windows&#xff09; Flutter SDK 下載 推薦使用中國鏡像站點下載 Flutter SDK&#xff0c;速度更快&#xff1a;中國環境 或者從官網下載…

碰一碰發視頻網頁版本開發的源碼搭建指南

引言 在數字化信息快速傳播的時代&#xff0c;近場通信&#xff08;NFC&#xff09;技術為信息交互帶來了新的便捷方式。通過網頁版本實現碰一碰發視頻功能&#xff0c;能夠讓用戶在瀏覽器環境中輕松實現視頻分享&#xff0c;拓展了視頻傳播的途徑。本文將詳細介紹碰一碰發視頻…

OMNIWeb 數據介紹

網址&#xff1a;SPDF - OMNIWeb Service 注&#xff1a;OMNI并非特定縮寫&#xff0c;僅表示"多樣化"含義。 About the Data All the data to which this interface and its multiple underlying interfaces provide access have in common that they are relevan…

Python學習(二)操作列表

一、列表的遍歷 每個縮進的代碼行都是循環的一部分&#xff0c;且將針對列表中的每個值都執行一次。因此&#xff0c;可對列表中的每個值執行任意次數的操作。 magicians [alice, david, carolina] for magician in magicians:print(magician)注意&#xff1a; 1、遍歷的時…

淺析RAG技術:大語言模型的知識增強之道

淺析RAG技術&#xff1a;大語言模型的知識增強之道 &#x1f3e0; 引言&#xff1a;當生成遇到檢索 在人工智能領域&#xff0c;大型語言模型(LLMs)如GPT-4、Llama3等展現出了驚人的文本生成能力&#xff0c;但它們也面臨著知識滯后、事實性錯誤等挑戰。Retrieval-Augmented …

Linux Vim 編輯器的使用

Vim 編輯器的使用 一、安裝及介紹二、基礎操作三、高級功能四、配置與插件 一、安裝及介紹 Vim是一款強大且高度可定制的文本編輯器&#xff0c;相當于 Windows 中的記事本。具備命令、插入、底行等多種模式。它可通過簡單的鍵盤命令實現高效的文本編輯、查找替換、分屏操作等…

Windows 圖形顯示驅動開發-WDDM 2.4功能-基于 IOMMU 的 GPU 隔離(三)

幀緩沖區保留 對于必須在電源轉換期間將幀緩沖區的保留部分保存到系統內存的驅動程序&#xff0c;Dxgkrnl 會在適配器初始化時對所需內存進行用量認可。 如果驅動程序報告 IOMMU 隔離支持&#xff0c;則 Dxgkrnl 將在查詢物理適配器上限后立即調用 DXGKDDI_QUERYADAPTERINFO&a…

UML之擴展用例

UML用例建模面向業務實現或者系統功能&#xff0c;每一個用例實現一個完整的業務或者功能。而一個完整的用例也可能有一些不是必需的附加功能&#xff0c;或者在該用例已經實現后需要添加一些新功能&#xff0c;此時可以通過UML提供的擴展用例機制描述類似這樣的場景。 例如對…

大數據學習(95)-謂詞下推

&#x1f34b;&#x1f34b;大數據學習&#x1f34b;&#x1f34b; &#x1f525;系列專欄&#xff1a; &#x1f451;哲學語錄: 用力所能及&#xff0c;改變世界。 &#x1f496;如果覺得博主的文章還不錯的話&#xff0c;請點贊&#x1f44d;收藏??留言&#x1f4dd;支持一…

行式存儲(Row-based Storage)與列式存儲(Column-based Storage)詳細對比

行式存儲&#xff08;Row-based Storage&#xff09;與列式存儲&#xff08;Column-based Storage&#xff09;詳細對比 1. 數據組織方式 類型行式存儲列式存儲存儲結構按行存儲數據&#xff0c;每條記錄的所有字段&#xff08;列&#xff09;連續存放&#xff08;如一條訂單的…

Seg-Zero:通過認知強化實現的推理鏈引導分割

文章目錄 速覽摘要1. 引言2. 相關工作2.1. 大模型中的推理能力2.2. 結合推理的語義分割2.3. 用于分割任務的 MLLMs 3. 方法3.1. 流程建模&#xff08;Pipeline Formulation&#xff09;3.2. Seg-Zero 模型3.3. 獎勵函數&#xff08;Reward Functions&#xff09;3.4. 訓練&…

win server2022 限制共享文件夾d

點擊配額管理中的配額 然后創建配額 導入要配額的文件即可 然后確定即可

Docker容器部署Java項目(詳細版)

&#x1f91f;致敬讀者 &#x1f7e9;感謝閱讀&#x1f7e6;笑口常開&#x1f7ea;生日快樂?早點睡覺 &#x1f4d8;博主相關 &#x1f7e7;博主信息&#x1f7e8;博客首頁&#x1f7eb;專欄推薦&#x1f7e5;活動信息 文章目錄 Docker容器部署Java項目1. 環境及準備2. 項目…

C語言深度解析:從零到系統級開發的完整指南

一、C語言的核心特性與優勢 1. 高效性與直接硬件控制 C語言通過編譯為機器碼的特性&#xff0c;成為系統級開發的首選語言。例如&#xff0c;Linux內核通過C語言直接操作內存和硬件寄存器&#xff0c;實現高效進程調度。 關鍵點&#xff1a; malloc/free直接管理內存&#…

Pytorch實現之基于GAN+序列后向選擇的情緒識別增強方法

簡介 簡介:在WGAN-GP+CGAN的基礎上利用了序列后向選擇方法來挑選優質樣本補充到訓練集當中,豐富訓練數據集。 論文題目:基于生成對抗網絡的情緒識別數據增強方法 期刊:傳感技術學報 摘要:使用深度學習方法構建高準確率的情緒識別模型需要大量的情緒腦電數據。 生成對抗…