日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php中使用JWT

發布時間:2024/9/30 php 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php中使用JWT 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

https://baijiahao.baidu.com/s?id=1608021814182894637&wfr=spider&for=pc
https://www.jb51.net/article/146790.htm
JWT是什么
JWT是json web token縮寫。它將用戶信息加密到token里,服務器不保存任何用戶信息。服務器通過使用保存的密鑰驗證token的正確性,只要正確即通過驗證。基于token的身份驗證可以替代傳統的cookie+session身份驗證方法。

它定義了一種用于簡潔,自包含的用于通信雙方之間以 JSON 對象的形式安全傳遞信息的方法。JWT 可以使用 HMAC 算法或者是 RSA 的公鑰密鑰對進行簽名。它具備兩個特點:

簡潔(Compact):可以通過URL, POST 參數或者在 HTTP header 發送,因為數據量小,傳輸速度快

自包含(Self-contained):負載中包含了所有用戶所需要的信息,避免了多次查詢數據庫

JWT由三個部分組成:header.payload.signature

以下示例以JWT官網為例
header部分:

{"alg": "HS256","typ": "JWT" }

對應base64UrlEncode編碼為:eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9
說明:該字段為json格式。alg字段指定了生成signature的算法,默認值為HS256,typ默認值為JWT
payload部分:

{"sub": "1234567890","name": "John Doe","iat": 1516239022 }

對應base64UrlEncode編碼為:eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ
說明:該字段為json格式,表明用戶身份的數據,可以自己自定義字段,很靈活。sub 面向的用戶,name 姓名 ,iat 簽發時間。例如可自定義示例如下:

{"iss": "admin", //該JWT的簽發者"iat": 1535967430, //簽發時間"exp": 1535974630, //過期時間"nbf": 1535967430, //該時間之前不接收處理該Token"sub": "www.admin.com", //面向的用戶"jti": "9f10e796726e332cec401c569969e13e" //該Token唯一標識 }

signature部分:

HMACSHA256(base64UrlEncode(header) + "." +base64UrlEncode(payload),123456 ) 對應的簽名為:keH6T3x1z7mmhKL1T3r9sQdAxxdzB6siemGMr_6ZOwU

最終得到的JWT的json為(header.payload.signature):eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.keH6T3x1z7mmhKL1T3r9sQdAxxdzB6siemGMr_6ZOwU
說明:對header和payload進行base64UrlEncode編碼后進行拼接。通過key(這里是123456)進行HS256算法簽名。

PHP如何實現JWT
作者使用的是PHP 7.0.31,不廢話,直接上代碼,新建jwt.php,復制粘貼如下

<?php /*** PHP實現jwt*/ class Jwt {//頭部private static $header=array('alg'=>'HS256', //生成signature的算法'typ'=>'JWT' //類型);//使用HMAC生成信息摘要時所使用的密鑰private static $key='123456';/*** 獲取jwt token* @param array $payload jwt載荷 格式如下非必須* [* 'iss'=>'jwt_admin', //該JWT的簽發者* 'iat'=>time(), //簽發時間* 'exp'=>time()+7200, //過期時間* 'nbf'=>time()+60, //該時間之前不接收處理該Token* 'sub'=>'www.admin.com', //面向的用戶* 'jti'=>md5(uniqid('JWT').time()) //該Token唯一標識* ]* @return bool|string*/public static function getToken( $payload){if(is_array($payload)){$base64header=self::base64UrlEncode(json_encode(self::$header,JSON_UNESCAPED_UNICODE));$base64payload=self::base64UrlEncode(json_encode($payload,JSON_UNESCAPED_UNICODE));$token=$base64header.'.'.$base64payload.'.'.self::signature($base64header.'.'.$base64payload,self::$key,self::$header['alg']);return $token;}else{return false;}}/*** 驗證token是否有效,默認驗證exp,nbf,iat時間* @param string $Token 需要驗證的token* @return bool|string*/public static function verifyToken( $Token){$tokens = explode('.', $Token);if (count($tokens) != 3)return false;list($base64header, $base64payload, $sign) = $tokens;//獲取jwt算法$base64decodeheader = json_decode(self::base64UrlDecode($base64header), JSON_OBJECT_AS_ARRAY);if (empty($base64decodeheader['alg']))return false;//簽名驗證if (self::signature($base64header . '.' . $base64payload, self::$key, $base64decodeheader['alg']) !== $sign)return false;$payload = json_decode(self::base64UrlDecode($base64payload), JSON_OBJECT_AS_ARRAY);//簽發時間大于當前服務器時間驗證失敗if (isset($payload['iat']) && $payload['iat'] > time())return false;//過期時間小宇當前服務器時間驗證失敗if (isset($payload['exp']) && $payload['exp'] < time())return false;//該nbf時間之前不接收處理該Tokenif (isset($payload['nbf']) && $payload['nbf'] > time())return false;return $payload;}/*** base64UrlEncode https://jwt.io/ 中base64UrlEncode編碼實現* @param string $input 需要編碼的字符串* @return string*/private static function base64UrlEncode( $input){return str_replace('=', '', strtr(base64_encode($input), '+/', '-_'));}/*** base64UrlEncode https://jwt.io/ 中base64UrlEncode解碼實現* @param string $input 需要解碼的字符串* @return bool|string*/private static function base64UrlDecode( $input){$remainder = strlen($input) % 4;if ($remainder) {$addlen = 4 - $remainder;$input .= str_repeat('=', $addlen);}return base64_decode(strtr($input, '-_', '+/'));}/*** HMACSHA256簽名 https://jwt.io/ 中HMACSHA256簽名實現* @param string $input 為base64UrlEncode(header).".".base64UrlEncode(payload)* @param string $key* @param string $alg 算法方式* @return mixed*/private static function signature( $input, $key, $alg = 'HS256'){$alg_config=array('HS256'=>'sha256');return self::base64UrlEncode(hash_hmac($alg_config[$alg], $input, $key,true));} }//測試和官網是否匹配begin $payload=array('sub'=>'1234567890','name'=>'John Doe','iat'=>1516239022); $jwt=new Jwt; $token=$jwt->getToken($payload); echo "<pre>"; echo $token;//對token進行驗證簽名 $getPayload=$jwt->verifyToken($token); echo "<br><br>"; var_dump($getPayload); echo "<br><br>"; //測試和官網是否匹配end//自己使用測試begin $payload_test=array('iss'=>'admin','iat'=>time(),'exp'=>time()+7200,'nbf'=>time(),'sub'=>'www.admin.com','jti'=>md5(uniqid('JWT').time()));; $token_test=Jwt::getToken($payload_test); echo "<pre>"; echo $token_test;//對token進行驗證簽名 $getPayload_test=Jwt::verifyToken($token_test); echo "<br><br>"; var_dump($getPayload_test); echo "<br><br>"; //自己使用時候end

總結

以上是生活随笔為你收集整理的php中使用JWT的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。