本文實(shí)例講述了ThinkPHP5框架中使用JWT的方法。分享給大家供大家參考,具體如下:
JWT下載地址:https://jwt.io
可以直接去github上下載,也可以使用composer
使用composer的話要確保你的電腦上安裝了composer,進(jìn)入項(xiàng)目根目錄下載即了,自動(dòng)會(huì)放在vendor目錄下
創(chuàng)建文件
我是放在common目錄下
![](http://img.jbzj.com/file_images/article/202006/202063100622339.png?20205310656)
使用教程
github都有的
貼源碼
JWTAuth.php
?php
namespace app\common\Auth;
use \Lcobucci\JWT\Builder;
use \Lcobucci\JWT\Signer\Hmac\Sha256;
use \Lcobucci\JWT\Parser;
use \Lcobucci\JWT\ValidationData;
/**
* 單例模式
*/
class JWTAuth
{
private static $instance;
/**
* JWT TOKEN
* @var [type]
*/
private $token;
/**
* 頒發(fā)
* @var string
*/
private $iss = 'api.test.com';
/**
* 接收
* @var string
*/
private $aud = 'app.com';
private $uid;
private $secrect="#$%#$%*^(*(*(";
private $decodeToken;
public static function getInstance() {
if(is_null(self::$instance)) {
self::$instance = new self();
}
return self::$instance;
}
private function __contruct(){
}
private function __clone(){
}
public function encode(){
$time = time();
$this->token = (new builder())->setHeader('alg','HS256')
->setIssuer($this->iss)
->setAudience($this->aud)
->setIssuedAt($time) //生效時(shí)間
->setExpiration($time + 20)//過(guò)期時(shí)間
->set('uid',$this->uid)
->sign(new Sha256(), $this->secrect)//加密算法
->getToken();
return $this;
}
public function getToken(){
return (string)$this->token;
}
public function setToken($token){
$this->token = $token;
return $this;
}
/**
* 用戶信息uid
* @param [type] $uid [description]
*/
public function setUid($uid){
$this->uid = $uid;
return $this;
}
public function jsonDecode(){
$token = $this->token;
$this->decodeToken = (new Parser())->parse((string) $token);
// echo $this->decodeToken->getClaim('uid');
return $this->decodeToken;
}
/**
* 驗(yàn)證令牌是否有效
* @return [type] [description]
*/
public function validate(){
$data = new ValidationData();
$data->setIssuer($this->iss);
$data->setAudience($this->aud);
return $this->jsonDecode()->validate($data);
}
/**
* 簽名來(lái)驗(yàn)證令牌在生成后是否未被修改
* @return [type] [description]
*/
public function verify(){
$result = $this->jsonDecode()->verify(new Sha256(), $this->secrect);
return $result;
}
}
user.php 用來(lái)測(cè)試
?php
namespace app\index\controller;
use app\common\Auth\JWTAuth;
class User{
public function login(){
$jwtAuth = JWTAuth::getInstance();
$token = $jwtAuth->setUid(1)->encode()->getToken();
echo $token;
// var_dump(success_json_data(['token'=>$token]));
}
public function check_login(){
$jwtAuth = JWTAuth::getInstance();
$jwtAuth->setToken('eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJpc3MiOiJhcGkudGVzdC5jb20iLCJhdWQiOiJhcHAuY29tIiwiaWF0IjoxNTU2MDk1MDI5LCJleHAiOjE1NTYwOTUwNDksInVpZCI6MX0.oi4rLbQFNZUJsW4fVHWiOQxfEmomuvldAV-gFKl2V74');
if($jwtAuth->validate() $jwtAuth->verify()){
echo '驗(yàn)證成功';
}else{
echo '登錄過(guò)期';
}
}
}
最后
jwt本身的話是不帶token刷新方法,所以一旦token過(guò)期,客戶端就要重新登錄。
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門教程》、《CI(CodeIgniter)框架進(jìn)階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對(duì)大家基于ThinkPHP框架的PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- 詳解Docker 下開(kāi)發(fā) hyperf 完整使用示例
- PhpStorm 如何優(yōu)雅的調(diào)試Hyperf的方法步驟
- php框架知識(shí)點(diǎn)的整理和補(bǔ)充
- php中Workerman框架實(shí)例講解
- 淺談php常用的7大框架的優(yōu)缺點(diǎn)
- php框架CI(codeigniter)自動(dòng)加載與自主創(chuàng)建對(duì)象操作實(shí)例分析
- Thinkphp5框架異常處理操作實(shí)例分析
- Thinkphp5框架中引入Markdown編輯器操作示例
- 淺談減少Hyperf框架的掃描時(shí)間