2
0

AuthApi.php 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. <?php
  2. namespace App\Http\Api;
  3. use Illuminate\Support\Facades\Log;
  4. use Illuminate\Http\Request;
  5. use Firebase\JWT\JWT;
  6. use Firebase\JWT\Key;
  7. class AuthApi
  8. {
  9. public static function getJwtKey()
  10. {
  11. return config('mint.app.jwt_secrets_key');
  12. }
  13. public static function getToken(Request $request)
  14. {
  15. $token = $request->bearerToken();
  16. return $token;
  17. }
  18. public static function current(Request $request)
  19. {
  20. $token = $request->bearerToken();
  21. if ($token) {
  22. try {
  23. $jwt = JWT::decode($token, new Key(self::getJwtKey(), 'HS512'));
  24. } catch (\Exception $e) {
  25. return false;
  26. }
  27. if ($jwt->exp < time()) {
  28. //过期
  29. return false;
  30. } else {
  31. //有效的token
  32. return ['user_uid' => $jwt->uid, 'user_id' => $jwt->id];
  33. }
  34. } else if (isset($_COOKIE['user_uid'])) {
  35. return [
  36. 'user_uid' => $_COOKIE['user_uid'],
  37. 'user_id' => $_COOKIE['user_id']
  38. ];
  39. } else {
  40. return false;
  41. }
  42. }
  43. }