JWT在PHP的使用

jwt扩展 lcobucci/jwt

php环境: PHP7.2

首先是:
composer require lcobucci/jwt

然后直接上代码吧,要简明的多

<?php
require_once './vendor/autoload.php';
use Lcobucci\JWT\Builder;
use Lcobucci\JWT\Parser;
use Lcobucci\JWT\Configuration;
use Lcobucci\JWT\Signer\Hmac\Sha256;
use Lcobucci\JWT\Signer\Key;
use Lcobucci\JWT\ValidationData;

$signer  = new Sha256();
$secret = md5('aaa');       // 自定义加密串
$time = time();

$token = (new Builder())->issuedBy('http://localhost') // 配置发布者
                        ->permittedFor('http://localhost') // 配置访问者
                        ->identifiedBy('4f1g23a12aa', true) // Configures the id (jti claim), replicating as a header item
                        ->issuedAt($time) // 配置令牌被发出的时间
                        ->canOnlyBeUsedAfter($time + 60) // 配置令牌多长时间后可以使用
                        ->expiresAt($time + 3600) // 配置令牌的过期时间
                        ->withClaim('uid', 123) // 自定义附带信息
                        ->getToken($signer, new Key($secret));

pp(['密钥验证' => $token->verify($signer, $secret)], 1);
pp([
    '发出日期' => date('Y-m-d H:i:s', $token->getClaim('iat')),
    '有效时间' => date('Y-m-d H:i:s', $token->getClaim('nbf')),
    '过期时间' => date('Y-m-d H:i:s', $token->getClaim('exp'))
]);
$token = (string) $token; // token其实是个对象, 格式化为字符串输出

echo "=====================解析token==================================="."<br />";
pareToken($token);

/**
 * 解析token function
 *
 * @param [type] $encrypt_str
 * @return void
 */
function pareToken($encrypt_str) {
    $token = (new Parser())->parse($encrypt_str); // 将token字符串格式化为对象
    pp(['解析后 jti', $token->getHeader('jti')]); // will print "4f1g23a12aa"
    pp(['解析后 Claims信息', $token->getClaims()]); // will print "http://example.com"
    // pp(['解析后 uid', $token->getClaim('uid')]); // will print "1"
}

echo "=======================验证token有效及正确性========================="."<br />";
valiToken($token, $time);

/**
 * 验证token function
 *
 * @return void
 */
function valiToken($token, $time) {
    $token = (new Parser())->parse($token); // 格式化为对象
    $data = new ValidationData(); // It will use the current time to validate (iat, nbf and exp)
    $data->setIssuer('http://localhost');
    $data->setAudience('http://localhost');
    $data->setId('4f1g23a12aa');

    pp(['验证token有效性', (int) $token->validate($data), formatDate($data)]); // false,因为令牌不能在now()+ 60之前使用

    $data->setCurrentTime($time + 61); // 将验证时间更改为将来的时间
    pp(['+ 61秒后验证token时间有效性', (int) $token->validate($data), formatDate($data)]); // 是,因为当前时间在“ nbf”和“ exp”声明之间

    $data->setCurrentTime($time + 4000); // 将验证时间更改为将来的时间
    pp(['当前时间+4000', (int) $token->validate($data), formatDate($data)]); // 错误,因为令牌已过期,因为当前时间大于exp
}

/**
 * 打印函数
 * @param $arr
 * @param int $type
 */
function pp($arr, $type = 0) {
    echo "<pre>";
    $type == 0 ? print_r($arr) : var_dump($arr);
    echo "<br />";
    echo "</pre>";
}

/**
 * 格式化时间
 * @param $date
 * @return array
 */
function formatDate($date) {
    return [
        '发出日期' => date('Y-m-d H:i:s', $date->get('iat')),
        '有效时间' => date('Y-m-d H:i:s', $date->get('nbf')),
        '过期时间' => date('Y-m-d H:i:s', $date->get('exp'))
    ];
}

运行

360截图16280724549761.png
360截图16650220154544.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容