thinkphp6集成JWT

1.引入php-jwt包

composer require firebase/php-jwt


2.代码

控制器文件:app\api\lib

<?php

namespace app\api\lib;

use Firebase\JWT\ExpiredException;
use Firebase\JWT\JWT as JWTUtil;
use think\Exception;
use think\response\Json;

class JWT
{
    //生产token
    public static function createjwt($userid = null): Json
    {
        $key = md5(env('TOKEN.KEY', "pyg")); //jwt的签发密钥,验证token的时候需要用到
        $time = time(); //签发时间
        $expire = $time + 14400; //过期时间
        $token = array(
            "user_id" => $userid,
            "iss" => env('TOKEN.iss', ""),//签发组织
            "aud" => env('TOKEN.aud', ""), //签发作者
            "iat" => $time,
            "nbf" => $time,
            "exp" => $expire
        );
        return json(JWTUtil::encode($token, $key));
    }

    // 验证token
    public static function verifyjwt($jwt)
    {
        if (in_array($jwt, cache("delete_token"))) {
            throw new Exception("token过期", 400);
        }
        $key = md5(env('TOKEN.KEY', "pyg")); //jwt的签发密钥,验证token的时候需要用到
        try {
            $jwtAuth = json_encode(JWTUtil::decode($jwt, $key, array("HS256")));
            $authInfo = json_decode($jwtAuth, true);
            if (!$authInfo['user_id']) {
                throw new Exception("用户不存在", 400);
            }
            return json($authInfo);
        } catch (ExpiredException $e) {
            throw new Exception("token过期", 400);
        } catch (\Exception $e) {
            throw new Exception($e->getMessage(), $e->getCode());
        }
    }

    //从请求信息中获取token令牌
    public static function getRequestToken()
    {
        if (empty($_SERVER['HTTP_AUTHORIZATION'])) {
            return false;
        }

        $header = $_SERVER['HTTP_AUTHORIZATION'];
        $method = 'bearer';
        //去除token中可能存在的bearer标识
        return trim(str_ireplace($method, '', $header));
    }
}

3.在env 目录里加入如下代码:

[TOKEN]
KEY= pyg
iss = http://admin.tp.com
aud= pyg

4.生成token值 

public static function setToken($userid){
        try {
            $token = JWT::createjwt($userid)->getData();
        }catch (Exception $exception){
            throw new Exception("token生成失效",500);
        }

        return $token;
    }

5.效果如图所示

生成token

图1.生成token

token里面解析的数据

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值