摘要:基于的身份驗證可以替代傳統的身份驗證方法。例如可自定義示例如下該的簽發者簽發時間過期時間該時間之前不接收處理該面向的用戶該唯一標識部分對應的簽名為最終得到的的為說明對和進行編碼后進行拼接。
JWT是什么
JWT是json web token縮寫。它將用戶信息加密到token里,服務器不保存任何用戶信息。服務器通過使用保存的密鑰驗證token的正確性,只要正確即通過驗證。基于token的身份驗證可以替代傳統的cookie+session身份驗證方法。以下示例以JWT官網為例 header部分:JWT由三個部分組成:header.payload.signature
{ "alg": "HS256", "typ": "JWT" }
對應base64UrlEncode編碼為:eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9
說明:該字段為json格式。alg字段指定了生成signature的算法,默認值為HS256,typ默認值為JWT
{ "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唯一標識 }
HMACSHA256( base64UrlEncode(header) + "." + base64UrlEncode(payload), 123456 )
對應的簽名為:keH6T3x1z7mmhKL1T3r9sQdAxxdzB6siemGMr_6ZOwU
最終得到的JWT的json為(header.payload.signature):eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJzdWIiOiIxMjM0NTY3ODkwIiwibmFtZSI6IkpvaG4gRG9lIiwiaWF0IjoxNTE2MjM5MDIyfQ.keH6T3x1z7mmhKL1T3r9sQdAxxdzB6siemGMr_6ZOwUJWT使用流程
說明:對header和payload進行base64UrlEncode編碼后進行拼接。通過key(這里是123456)進行HS256算法簽名。
初次登錄:用戶初次登錄,輸入用戶名密碼
密碼驗證:服務器從數據庫取出用戶名和密碼進行驗證
生成JWT:服務器端驗證通過,根據從數據庫返回的信息,以及預設規則,生成JWT
返還JWT:服務器的HTTP RESPONSE中將JWT返還
帶JWT的請求:以后客戶端發起請求,HTTP REQUEST
HEADER中的Authorizatio字段都要有值,為JWT
服務器驗證JWT
PHP如何實現JWT作者使用的是PHP 7.0.31,不廢話,直接上代碼,新建jwt.php,復制粘貼如下:
"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(array $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(string $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時間之前不接收處理該Token if (isset($payload["nbf"]) && $payload["nbf"] > time()) return false; return $payload; } /** * base64UrlEncode https://jwt.io/ 中base64UrlEncode編碼實現 * @param string $input 需要編碼的字符串 * @return string */ private static function base64UrlEncode(string $input) { return str_replace("=", "", strtr(base64_encode($input), "+/", "-_")); } /** * base64UrlEncode https://jwt.io/ 中base64UrlEncode解碼實現 * @param string $input 需要解碼的字符串 * @return bool|string */ private static function base64UrlDecode(string $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(string $input, string $key, string $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 ""; echo $token; //對token進行驗證簽名 $getPayload=$jwt->verifyToken($token); echo "
"; var_dump($getPayload); echo "
"; //測試和官網是否匹配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 ""; echo $token_test; //對token進行驗證簽名 $getPayload_test=Jwt::verifyToken($token_test); echo "
"; var_dump($getPayload_test); echo "
"; //自己使用時候end
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/29373.html
摘要:今天我們來結合實例給大家講述的實戰應用,就是如何使用前端與后端實現用戶登錄鑒權認證的過程。只用了一個串,建立前后端的驗證的數據傳遞,實現了有效的登錄鑒權過程。 今天我們來結合實例給大家講述JWT(Json Web Token)的實戰應用,就是如何使用前端Axios與后端PHP實現用戶登錄鑒權認證的過程。 文中涉及的重要知識點: axios異步請求:axios-基于Promise的HTT...
摘要:默認的時間為周。大概意思就是如果用戶有一個,那么他可以帶著他的過來領取新的,直到周的時間后,他便無法繼續刷新了,需要重新登錄。指定在刷新令牌時要保留的聲明密鑰。為了使令牌無效,您必須啟用黑名單。指定用于對用戶進行身份驗證的提供程序。 showImg(https://segmentfault.com/img/remote/1460000012606251?w=1920&h=1280); ...
摘要:框架具有輕便,開源的優點,所以本譯見構建用戶管理微服務五使用令牌和來實現身份驗證往期譯見系列文章在賬號分享中持續連載,敬請查看在往期譯見系列的文章中,我們已經建立了業務邏輯數據訪問層和前端控制器但是忽略了對身份進行驗證。 重拾后端之Spring Boot(四):使用JWT和Spring Security保護REST API 重拾后端之Spring Boot(一):REST API的搭建...
摘要:如何做用戶認證根據文檔描述,提供用戶認證的接口,他的核心是看守器和提供器,看守器定義怎么認證用戶,提供器定義怎么檢索用戶。 最近的一個PHP項目,上一個項目是采用ThinkPHP來弄的,因為很早就聽說過Laravel的大名,所以進了Laravel的官網,意外發現了Lumen,正好我項目是提供API的,所以選擇了Lumen,因為是Laravel的精簡版,看了幾天的Laravel文檔,也總...
摘要:概念英文全稱,單點登錄。登錄如上述流程圖一致。系統和系統使用認證登錄。退出上圖,表示的是從某一個系統退出的流程圖。與的關系如果企業有多個管理系統,現由原來的每個系統都有一個登錄,調整為統一登錄認證。 概念 SSO 英文全稱 Single Sign On,單點登錄。 在多個應用系統中,只需要登錄一次,就可以訪問其他相互信任的應用系統。 比如:淘寶網(www.taobao.com),天貓網...
閱讀 2961·2021-11-17 09:33
閱讀 3124·2021-11-16 11:52
閱讀 486·2021-09-26 09:55
閱讀 2980·2019-08-30 15:52
閱讀 1320·2019-08-30 15:44
閱讀 1266·2019-08-30 13:59
閱讀 802·2019-08-30 13:08
閱讀 1167·2019-08-30 10:50