从https://jwt.io/中找到目前github上目前star最多的jwt包:
PHP-JWT
A simple library to encode and decode JSON Web Tokens (JWT) in PHP, conforming to RFC 7519.
Installation
Use composer to manage your dependencies and download PHP-JWT:
composer require firebase/php-jwt
Example
use \Firebase\JWT\JWT;
$key = "example_key";
$payload = array(
"iss" => "http://example.org",
"aud" => "http://example.com",
"iat" => 1356999524,
"nbf" => 1357000000
);
/**
* IMPORTANT:
* You must specify supported algorithms for your application. See
* https://tools.ietf.org/html/draft-ietf-jose-json-web-algorithms-40
* for a list of spec-compliant algorithms.
*/
$jwt = JWT::encode($payload, $key);
$decoded = JWT::decode($jwt, $key, array('HS256'));
print_r($decoded);
/*
NOTE: This will now be an object instead of an associative array. To get
an associative array, you will need to cast it as such:
*/
$decoded_array = (array) $decoded;
/**
* You can add a leeway to account for when there is a clock skew times between
* the signing and verifying servers. It is recommended that this leeway should
* not be bigger than a few minutes.
*
* Source: http://self-issued.info/docs/draft-ietf-oauth-json-web-token.html#nbfDef
*/
JWT::$leeway = 60; // $leeway in seconds
$decoded = JWT::decode($jwt, $key, array('HS256'));
?>
Example with RS256 (openssl)
use \Firebase\JWT\JWT;
$privateKey &#61; <<
-----BEGIN RSA PRIVATE KEY-----
MIICXAIBAAKBgQC8kGa1pSjbSYZVebtTRBLxBz5H4i2p/llLCrEeQhta5kaQu/Rn
vuER4W8oDH3&#43;3iuIYW4VQAzyqFpwuzjkDI&#43;17t5t0tyazyZ8JXw&#43;KgXTxldMPEL9
5&#43;qVhgXvwtihXC1c5oGbRlEDvDF6Sa53rcFVsYJ4ehde/zUxo6UvS7UrBQIDAQAB
AoGAb/MXV46XxCFRxNuB8LyAtmLDgi/xRnTAlMHjSACddwkyKem8//8eZtw9fzxz
bWZ/1/doQOuHBGYZU8aDzzj59FZ78dyzNFoF91hbvZKkg&#43;6wGyd/LrGVEB&#43;Xre0J
Nil0GReM2AHDNZUYRv&#43;HYJPIOrB0CRczLQsgFJ8K6aAD6F0CQQDzbpjYdx10qgK1
cP59UHiHjPZYC0loEsk7s&#43;hUmT3QHerAQJMZWC11Qrn2N&#43;ybwwNblDKv&#43;s5qgMQ5
5tNoQ9IfAkEAxkyffU6ythpg/H0Ixe1I2rd0GbF05biIzO/i77Det3n4YsJVlDck
ZkcvY3SK2iRIL4c9yY6hlIhs&#43;K9wXTtGWwJBAO9Dskl48mO7woPR9uD22jDpNSwe
k90OMepTjzSvlhjbfuPN1IdhqvSJTDychRwn1kIJ7LQZgQ8fVz9OCFZ/6qMCQGOb
qaGwHmUK6xzpUbbacnYrIM6nLSkXgOAwv7XXCojvY614ILTK3iXiLBOxPu5Eu13k
eUz9sHyD6vkgZzjtxXECQAkp4Xerf5TGfQXGXhxIX52yH&#43;N2LtujCdkQZjXAsGdm
B2zNzvrlgRmgBrklMTrMYgm1NPcW&#43;bRLGcwgW2PTvNM&#61;
-----END RSA PRIVATE KEY-----
EOD;
$publicKey &#61; <<
-----BEGIN PUBLIC KEY-----
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC8kGa1pSjbSYZVebtTRBLxBz5H
4i2p/llLCrEeQhta5kaQu/RnvuER4W8oDH3&#43;3iuIYW4VQAzyqFpwuzjkDI&#43;17t5t
0tyazyZ8JXw&#43;KgXTxldMPEL95&#43;qVhgXvwtihXC1c5oGbRlEDvDF6Sa53rcFVsYJ4
ehde/zUxo6UvS7UrBQIDAQAB
-----END PUBLIC KEY-----
EOD;
$payload &#61; array(
"iss" &#61;> "example.org",
"aud" &#61;> "example.com",
"iat" &#61;> 1356999524,
"nbf" &#61;> 1357000000
);
$jwt &#61; JWT::encode($payload, $privateKey, &#39;RS256&#39;);
echo "Encode:\n" . print_r($jwt, true) . "\n";
$decoded &#61; JWT::decode($jwt, $publicKey, array(&#39;RS256&#39;));
/*
NOTE: This will now be an object instead of an associative array. To get
an associative array, you will need to cast it as such:
*/
$decoded_array &#61; (array) $decoded;
echo "Decode:\n" . print_r($decoded_array, true) . "\n";
?>
构建自定义类
namespace app\lib\tools;
use \Firebase\JWT\JWT;
/**
* 单例 一次请求中所有使用jwt的地方都是一个用户
*
*/
class JwtAuth
{
private $token;
private static $instance;
private $iss &#61; &#39;api.tets.com&#39;; //签发人
private $aud &#61; &#39;api.tets.com&#39;; //受众
private $key &#61; &#39;#dsafasieg92fsdyhb3290&$#%#&#64;342&#39;;
private $uid;
/**
* 单例模式 JwtAuth句柄
*/
public static function getInstance()
{
if (is_null(self::$instance)) {
self::$instance &#61; new self();
}
return self::$instance;
}
private function __construct()
{
}
private function __clone(){
}
public function encode()
{
$time &#61; time();
$payload &#61; array(
"iss" &#61;> $this->iss,
"aud" &#61;> $this->aud,
"iat" &#61;> $time,
"nbf" &#61;> $time,
"uid" &#61;> $this->uid
);
$this->token &#61; $jwt &#61; JWT::encode($payload, $this->key);
return $this;
}
public function getToken()
{
return (string)$this->token;
}
public function setToken($token)
{
$this->token &#61; $token;
return $this;
}
public function setUid($uid)
{
$this->uid &#61; $uid;
return $this;
}
}
public function decode()
{
$token &#61; Request::instance()->param(&#39;token&#39;);
$key &#61; &#39;#dsafasieg92fsdyhb3290&$#%#&#64;342&#39;;
// JWT::$leeway &#61; 60; // $leeway in seconds
$decoded &#61; JWT::decode($token, $key, array(&#39;HS256&#39;));
dd ($decoded);
}
public function login()
{
//通过认证后获取uid为304
$uid &#61; 304;
$jwtAuth &#61; JwtAuth::getInstance();
$token &#61; $jwtAuth->setUid($uid)->encode()->getToken();
return [
&#39;status&#39; &#61;> 100,
&#39;message&#39; &#61;> &#39;成功&#39;,
&#39;token&#39; &#61;> $token
];
}