thinkphp6 JWT

这篇博客详细介绍了在ThinkPHP6框架下实现JSON Web Token (JWT)的三种不同方法,包括引入php-jwt包,配置环境,权限控制等步骤,并提供了控制器和路由的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

                                         三种方法实现jwt

 方法一:

1.引入php-jwt包
composer require firebase/php-jwt

2.env

[TOKEN]
KEY = yyp
iss = http://admin.week3.com/
aud = zwx

3.htaccess 

 RewriteCond %{HTTP:Authorization} ^(.+)$
RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]

4.代码
控制器文件:app\api\controller\Jwt.php

<?php

namespace app\api\lib;
use app\BaseController;
use Firebase\JWT\ExpiredException;
use Firebase\JWT\JWT as JWTUtil;
use think\facade\Request;

class Jwt
{
    /**
     * 根据json web token设置的规则生成token
     * @return \think\response\Json
     */
    public function createjwt($userid=null)
    {
        //jwt的签发密钥,验证token的时候需要用到
        $key = md5(env('TOKEN.KEY','pyg'));
        //签发时间
        $time = time();
        //过期时间
        $expire = $time + 14400;
        $token = array(
            //暂时固定
            "user_id" => $userid,
            //签发组织
            "iss" => env('TOKEN.iss',''),
            //签发作者
            "aud" => env('TOKEN.aud',''),
            //颁发时间
            "iat" => $tim
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值