91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在php中利用JWT實現一個驗證功能

發布時間:2020-11-27 14:55:22 來源:億速云 閱讀:177 作者:Leah 欄目:開發技術

這篇文章將為大家詳細講解有關怎么在php中利用JWT實現一個驗證功能,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

代碼如下:

在vendor包中建立Jwt.php,建立類文件

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時間之前不接收處理該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($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));
 }
}

調用JWT驗證的方法,代碼如下:

1.構建token方法

public function makeToken(){
	 $uname=$this->uname;	$currtime=time();
	 if(empty($this->uname)){ echo json_encode(array('code'=>-1,'msg'=>'[主賬號]參數為空'),JSON_UNESCAPED_UNICODE);	exit(); }	
	 ....
	 //jwt驗證
	 vendor("Jwt.Jwt");
	 $jwt = new \Jwt();
//這里構造jwt參數,可以參照jwt規范,各字段可以自行定義內容	 $payload=array('iss'=>'xesport','sub'=>'xxx_player','name'=>$playerName,'iat'=>$currtime,'jti'=>md5(uniqid('JWT').$currtime));
	 $token=$jwt->getToken($payload); $this->token=$token;
	 $url='http://xxx?token='.$token;
	 $data=array('url'=>$url);
	 
	 echo json_encode(array('code'=>1,'data'=>$data,),JSON_UNESCAPED_UNICODE); exit();
 
	}

2.驗證token的方法

//驗證token
public function verifyToken(){
	 $token=$_REQUEST['token'];
	 if(empty($token)){ echo json_encode(array('code'=>-1,'msg'=>'[token]參數為空!'),JSON_UNESCAPED_UNICODE);	exit(); }
  vendor("Jwt.Jwt");
	 $jwt = new \Jwt();	 
	 $res_token=$jwt->verifyToken($token);
  //var_dump('res_token==',$res_token);
	 if(empty($res_token)){ echo json_encode(array('code'=>-2,'msg'=>'[token]驗證失敗!'),JSON_UNESCAPED_UNICODE);	exit(); }
	 $playerName=$res_token['name'];
	 //echo $playerName; die;
	 這里可以寫從數據庫查詢驗證user是否存在,返回 $userInfo 
	 if(empty($userInfo)){ echo json_encode(array('code'=>-3,'msg'=>'[token]驗證用戶無效!'),JSON_UNESCAPED_UNICODE);	exit(); }
	 $data=array('username'=>$playerName);
	 echo json_encode(array('code'=>1,'data'=>$data,'msg'=>'[token]驗證成功'),JSON_UNESCAPED_UNICODE);	exit();
	}

這樣,我們通過控制器方法調用該方法,傳遞參數token,就可以解析token中包含的認證憑據信息,從而做后續業務處理邏輯。

關于怎么在php中利用JWT實現一個驗證功能就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

武强县| 星子县| 永宁县| 毕节市| 佛山市| 泗洪县| 城固县| 永吉县| 勐海县| 平遥县| 界首市| 蓬溪县| 安西县| 安泽县| 北宁市| 东山县| 宿州市| 济宁市| 大英县| 九寨沟县| 宜良县| 吴旗县| 巩留县| 麦盖提县| 洛南县| 衡山县| 新昌县| 体育| 南川市| 苍梧县| 青阳县| 镇原县| 昌邑市| 喀喇| 鹤峰县| 文安县| 黄冈市| 宁武县| 界首市| 北流市| 星座|