php 使用 JWT (Lcobucci\JWT)UUID 插件

 php 使用 JWT (Lcobucci\JWT)UUID 插件

UUID 插件使用:

   安装插件: composer require ramsey/uuid

$uuid = Uuid::uuid1();

JWT 插件使用:

  安装插件 :composer require lcobucci/jwt 3.3.3 (注:代码对应3.3.3版本)

<?php

/**
 * JWT 工具类复制即用
 * Ambiton
 */
namespace app\tools;

use Lcobucci\JWT\Builder;
use Lcobucci\JWT\Signer\Key;
use Lcobucci\JWT\Signer\Hmac\Sha256;
use Lcobucci\JWT\ValidationData;
use Lcobucci\JWT\Parser;
use Ramsey\Uuid\Uuid;
use Symfony\Component\VarDumper\Cloner\Data;


class Token
{


    static private $_config=[
        'audience' => 'http://127.0.0.1/token',//接收人
        'id' => '1806',//token的唯一标识,这里只是一个简单示例
        'sign' => 'Ambition',//签名密钥
        'issuer' => 'http://127.0.0.1/user_id',//签发人
        'expire' => 3600*2 //有效期
    ];

    //生成token
    static public function getToken($k,$v)
    {
        $signer = new Sha256();
        $time = time();

        $token = (new Builder())->issuedBy(self::$_config['issuer'])  // 签发人
                                ->permittedFor(self::$_config['audience']) // 接收人
                                ->identifiedBy(self::$_config['id'], true) // 唯一标识 可以自己写,也可以随机生成
                                ->issuedAt($time) // 签发时间
                                ->canOnlyBeUsedAfter($time - 1) // 生效时间
                                ->expiresAt($time + self::$_config['expire']) // 过期时间
                                ->withClaim($k, $v) // 用户id
                                ->getToken($signer, new Key(self::$_config['sign'])); // 生成token
        return (string)$token;
    }

    //验证token
    static public function verifyToken($token)
    {
        $signer = new Sha256();
        $token = (new Parser())->parse((string) $token);
        $data = new ValidationData();

        //验证签发人
        $data->setIssuer(self::$_config['issuer']);
        //验证接收人
        $data->setAudience(self::$_config['audience']);
        //验证唯一表示
        $data->setId(self::$_config['id']);
        //签发人   和上述验证
        if($token->verify($signer, self::$_config['sign']) && $token->validate($data)){
            return true;
        }else{
            return false;
        }
    }

    //从token中获取信息
    static public function getUserId($token,$k)
    {
        $res = self::verifyToken($token);
        if (!$res){
            return '无效的token';
        }
        $token = (new Parser())->parse((string)$token);
        return $token->getClaim($k);
    }


}

JWT使用介绍:

 public function index(Request  $request)
    {
        
        $token = $request ->param('token');
//        生成JWT
        $Jwt = Token::getToken("userId",11);
//        验证JWT是否合法 返回Bool
        $tVerify =  Token::verifyToken($token);
//        通过token 换取用户id
        $userId =  Token::getUserId($token,"userId");
    }

   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值