tokenutil php,集成JWT-实现token用户身份验证机制

## 1. 引入php-jwt包

composer require firebase/php-jwt

## 2. 生成token

```

//生成token

public function createJwt($userId = 'zq')

{

$key = md5('zq8876!@!'); //jwt的签发密钥,验证token的时候需要用到

$time = time(); //签发时间

$expire = $time + 14400; //过期时间

$token = array(

"user_id" => $userId,

"iss" => "http://www.najingquan.com/",//签发组织

"aud" => "zhangqi", //签发作者

"iat" => $time,

"nbf" => $time,

"exp" => $expire

);

$jwt = JWTUtil::encode($token, $key);

return $jwt;

}

```

## 3. 验证token

```

//校验jwt权限API

public function verifyJwt($jwt = '')

{

$key = md5('zq8876!@!');

try {

$jwtAuth = json_encode(JWTUtil::decode($jwt, $key, array('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;

}

}

```

## 4. 测试

生成token

![](https://img.kancloud.cn/1e/a6/1ea669c6470c8dd8f4d45c720e5bd187_1531x361.png)

验证token

![](https://img.kancloud.cn/d9/49/d94957366e0503fb94b8554d69ffd5a3_1359x477.png)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值