tp6 token使用方法

本文介绍了在ThinkPHP6(TP6)框架中如何使用JSON Web Token(JWT)进行身份验证。首先,通过composer安装firebase/php-jwt库,接着引入JWT类。然后详细阐述了生成和验证token的步骤:调用getToken方法传入用户信息生成token,并从HTTP header中获取token,再通过checkToken方法验证其有效性。
摘要由CSDN通过智能技术生成

先安装jwt

composer require firebase/php-jwt
 

引入token类

use \Firebase\JWT\JWT;

生成token

public function getToken($userData=[]){
        $key='!@#$%*&';
        $token=[
            "iss"=>$key,
            "aud"=>'',
            "iat"=>time(),
            "nbf"=>time()+3,
            "exp"=> time()+7200,
            "data"=>[
                'user'=>$userData,
            ]
        ];
        //  print_r($token);
        $jwt = JWT::encode($token, $key, "HS256");  //根据参数生成了 token
        return $jwt;
}

验证token

public function checkToken($token){
        $key='!@#$%*&';
        $status=["code"=>2];
        try {
           
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TP6使用JWT的方法如下所示[^1][^2]: 1. 首先,使用Composer安装JWT库: ```shell composer require firebase/php-jwt ``` 2. 在TP6的配置文件`config/jwt.php`中,配置JWT的相关参数,例如密钥、过期时间等: ```php return [ // 密钥 'secret' => 'your-secret-key', // 过期时间(单位:分钟) 'expire' => 60, ]; ``` 3. 创建一个JWT工具类,例如`app\utils\JwtUtil.php`,用于生成和验证JWT: ```php <?php namespace app\utils; use Firebase\JWT\JWT; use think\facade\Config; class JwtUtil { // 生成JWT public static function generateToken($data) { $config = Config::get('jwt'); $payload = [ 'iss' => 'your-issuer', 'aud' => 'your-audience', 'iat' => time(), 'exp' => time() + $config['expire'] * 60, 'data' => $data, ]; $token = JWT::encode($payload, $config['secret']); return $token; } // 验证JWT public static function verifyToken($token) { $config = Config::get('jwt'); try { $decoded = JWT::decode($token, $config['secret'], ['HS256']); return $decoded->data; } catch (\Exception $e) { return false; } } } ``` 4. 在需要使用JWT的地方,调用`JwtUtil`类的方法进行生成和验证JWT: ```php <?php namespace app\controller; use app\utils\JwtUtil; class UserController { // 生成JWT public function generateJwt() { $data = [ 'user_id' => 1, 'username' => 'admin', ]; $token = JwtUtil::generateToken($data); return $token; } // 验证JWT public function verifyJwt($token) { $data = JwtUtil::verifyToken($token); if ($data) { // 验证通过 return $data; } else { // 验证失败 return 'Invalid token'; } } } ``` 以上是TP6使用JWT的方法,通过配置文件和自定义的JWT工具类,可以方便地生成和验证JWT。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值