JwtAuth.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
  4. // +----------------------------------------------------------------------
  5. // | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
  6. // +----------------------------------------------------------------------
  7. // | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
  8. // +----------------------------------------------------------------------
  9. // | Author: CRMEB Team <admin@crmeb.com>
  10. // +----------------------------------------------------------------------
  11. namespace crmeb\utils;
  12. use crmeb\exceptions\AdminException;
  13. use crmeb\services\CacheService;
  14. use Firebase\JWT\JWT;
  15. use think\facade\Env;
  16. /**
  17. * Jwt
  18. * Class JwtAuth
  19. * @package crmeb\utils
  20. */
  21. class JwtAuth
  22. {
  23. /**
  24. * token
  25. * @var string
  26. */
  27. protected $token;
  28. /**
  29. * 获取token
  30. * @param int|string $id
  31. * @param string $type
  32. * @param array $params
  33. * @return array
  34. */
  35. public function getToken($id, string $type, array $params = []): array
  36. {
  37. $host = app()->request->host();
  38. $time = time();
  39. $exp_time = strtotime('+ 30day');
  40. $params += [
  41. 'iss' => $host,
  42. 'aud' => $host,
  43. 'iat' => $time,
  44. 'nbf' => $time,
  45. 'exp' => $exp_time,
  46. ];
  47. $params['jti'] = compact('id', 'type');
  48. $token = JWT::encode($params, Env::get('app.app_key', 'default'));
  49. return compact('token', 'params');
  50. }
  51. /**
  52. * 解析token
  53. * @param string $jwt
  54. * @return array
  55. */
  56. public function parseToken(string $jwt): array
  57. {
  58. $this->token = $jwt;
  59. list($headb64, $bodyb64, $cryptob64) = explode('.', $this->token);
  60. $payload = JWT::jsonDecode(JWT::urlsafeB64Decode($bodyb64));
  61. return [$payload->jti->id, $payload->jti->type, $payload->pwd ?? ''];
  62. }
  63. /**
  64. * 验证token
  65. */
  66. public function verifyToken()
  67. {
  68. JWT::$leeway = 60;
  69. JWT::decode($this->token, Env::get('app.app_key', 'default'), array('HS256'));
  70. $this->token = null;
  71. }
  72. /**
  73. * 获取token并放入令牌桶
  74. * @param $id
  75. * @param string $type
  76. * @param array $params
  77. * @return array
  78. * @throws \Psr\SimpleCache\InvalidArgumentException
  79. */
  80. public function createToken($id, string $type, array $params = [])
  81. {
  82. $tokenInfo = $this->getToken($id, $type, $params);
  83. $exp = $tokenInfo['params']['exp'] - $tokenInfo['params']['iat'] + 60;
  84. $res = CacheService::set(md5($tokenInfo['token']), ['uid' => $id, 'type' => $type, 'token' => $tokenInfo['token'], 'exp' => $exp], (int)$exp, $type);
  85. if (!$res) {
  86. throw new AdminException(100023);
  87. }
  88. return $tokenInfo;
  89. }
  90. }