TP6(jwt)token


thinkphp jwt auth composer
https://github.com/QThans/jwt-auth
https://packagist.org/packages/thans/tp-jwt-auth
https://gitee.com/thans/jwt-auth

https://github.com/firebase/php-jwt
http://blog.daozys.com/goods_90.html

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、付费专栏及课程。

余额充值