首页 / 后端开发 / JWT-实现token用户身份验证机制

JWT-实现token用户身份验证机制

2023-02-28 02:28 后端开发 阅读 10055 来源 php先锋网

1. 引入php-jwt包

composer require firebase/php-jwt

2. 生成token

//生成token
public function createJwt($userId = 'zq')
{
    $key = md5('heghdrwgsd'); //jwt的签发密钥,验证token的时候需要用到
    $time = time(); //签发时间
    $expire = $time + 100; //过期时间
    $token = array(
        "user_id" => $userId,
        "iss" => "https://www.phpvan.com/",//签发组织
        "aud" => "zhangqi", //签发作者
        "iat" => $time,
        "nbf" => $time,
        "exp" => $expire
    );
    $jwt = JWT::encode($token, $key, 'HS256');
    return $jwt;
}

3. 验证token

//校验jwt权限API
public function verifyJwt($jwt = '')
{
    $key = md5('heghdrwgsd');
    try {
        $jwtAuth = json_encode(JWT::decode($jwt, new Key($key, 'HS256')));
        $authInfo = json_decode($jwtAuth, true);
        $msg = [];
        if (!empty($authInfo['user_id'])) {
            $msg = [
                'status' => 1001,
                'msg' => 'Token验证通过'
            ];
        } else {
            $msg = [
                'status' => 1002,
                'msg' => 'Token验证不通过,用户不存在'
            ];
        }
        return $msg;
    }  catch (\Firebase\JWT\ExpiredException $e) {
        echo json_encode([
            'status' => 1003,
            'msg' => 'Token过期'
        ]);
        exit;
    } catch (\Exception $e) {
        echo json_encode([
            'status' => 1002,
            'msg' => 'Token无效'
        ]);
        exit;
    }
}

以上为加解密方式,也可以用于参数加密, 在数组后面追加上个字段,例如 data

$token = array( "user_id" => $userId, "iss" => "https://www.phpvan.com/",//签发组织 "aud" => "zhangqi", //签发作者 "iat" => $time, "nbf" => $time, "exp" => $expire, "data" = []);

如对你有帮助,请多多分享,站点是php先锋网

猜你喜欢

  • 后端开发

    Python通过正则表达式去除(过滤)或者替换HTML标签

    本文实例介绍了Python通过正则表达式获取,去除(过滤)或者替换HTML标签的几种方法,具体内容如下

    2021-06-22 06:22 3233
  • 后端开发

    oss 上传文件返回值的url,返回自定义域名的url方法

    已经在后台设置了自定义域名,与bucket-name也已经绑定了,使用oss上传文件,返回值中的url怎么设置为自定义的域名

    2021-04-05 04:05 5558
  • 后端开发

    python开发环境的安装

    python开发环境的安装,分别介绍windows和mac下安装方式

    2021-04-11 04:11 2750
  • 后端开发

    thinkphp全站实现静态化页面

    模板完全静态化,也就是通过模板完全生成纯静态的网页,相比动态页面和伪静态页面更安全更利于SEO访问更快。

    2023-02-28 02:28 10344
  • 后端开发

    requests模块⼊⻔

    Python内置的urllib模块,用于访问网络资源。但是,它用起来比较麻烦,而且,缺少很多实用的高级功能。更好的方案是使用requests。它是一个Python第三方库,处理URL资源特别方便。

    2021-04-25 04:25 2764
  • 后端开发

    正则表达式入门

    Regular Expression, 正则表达式, ⼀种使⽤表达式的⽅式对字符串进⾏匹配的语法规则.我们抓取到的⽹⻚源代码本质上就是⼀个超⻓的字符串, 想从⾥⾯提取内容.⽤正则再合适不过了. 正则的优点: 速度快, 效率⾼, 准确性⾼ 正则的缺点: 新⼿上⼿难度有点⼉⾼.不过只要掌握了正则编写的逻辑关系, 写出⼀个提取⻚⾯内容的正则其实并不复杂正则的语法: 使⽤元字符进⾏排列组合⽤来匹配字符串

    2021-04-25 04:25 856