1.定义类
class JWT
{
protected $secret;
public function __construct($secret)
{
$this->secret = $secret;
}
public function encode($payload)
{
$header = [
'typ' => 'JWT',
'alg' => 'HS256'
];
$header = base64_encode(json_encode($header));
$payload = base64_encode(json_encode($payload));
$signature = hash_hmac('sha256', "$header.$payload", $this->secret, true);
$signature = base64_encode($signature);
return "$header.$payload.$signature";
}
public function decode($token)
{
list($header, $payload, $signature) = explode('.', $token);
$data = "$header.$payload";
$hash = hash_hmac('sha256', $data, $this->secret, true);
$hash = base64_encode($hash);
if ($hash !== $signature) {
throw new Exception('Invalid token signature');
}
$payload = json_decode(base64_decode($payload), true);
if (!is_array($payload)) {
throw new Exception('Invalid token payload');
}
return $payload;
}
}
2.使用类
// 设置加密密钥
$secret = 'mysecretpassword';
// 创建 JWT 对象
$jwt = new JWT($secret);
// 要加密的信息
$payload = ['username' => 'Alice', 'email' => 'alice@example.com'];
// 加密信息
$encoded_payload = $jwt->encode($payload);
// 输出加密后的信息
echo $encoded_payload . PHP_EOL;
// 解密信息
$decoded_payload = $jwt->decode($encoded_payload);
// 输出解密后的信息
print_r($decoded_payload);