LoginMiddleware.php 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | likeadmin快速开发前后端分离管理后台(PHP版)
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
  8. // | github下载:https://github.com/likeshop-github/likeadmin
  9. // | 访问官网:https://www.likeadmin.cn
  10. // | likeadmin团队 版权所有 拥有最终解释权
  11. // +----------------------------------------------------------------------
  12. // | author: likeadminTeam
  13. // +----------------------------------------------------------------------
  14. declare (strict_types=1);
  15. namespace app\adminapi\http\middleware;
  16. use app\common\cache\AdminTokenCache;
  17. use app\adminapi\service\AdminTokenService;
  18. use app\common\service\JsonService;
  19. use think\facade\Config;
  20. /**
  21. * 登录中间件
  22. * Class LoginMiddleware
  23. * @package app\adminapi\http\middleware
  24. */
  25. class LoginMiddleware
  26. {
  27. /**
  28. * @notes 登录验证
  29. * @param $request
  30. * @param \Closure $next
  31. * @return mixed|\think\response\Json
  32. * @author 令狐冲
  33. * @date 2021/7/1 17:33
  34. */
  35. public function handle($request, \Closure $next)
  36. {
  37. $token = $request->header('token');
  38. //判断接口是否免登录
  39. $isNotNeedLogin = $request->controllerObject->isNotNeedLogin();
  40. //不直接判断$isNotNeedLogin结果,使不需要登录的接口通过,为了兼容某些接口可以登录或不登录访问
  41. if (empty($token) && !$isNotNeedLogin) {
  42. //没有token并且该地址需要登录才能访问
  43. return JsonService::fail('请先进行登录', [], 0, 0);
  44. }
  45. $adminInfo = (new AdminTokenCache())->getAdminInfo($token);
  46. if (empty($adminInfo) && !$isNotNeedLogin) {
  47. //token过期无效并且该地址需要登录才能访问
  48. return JsonService::fail('登录超时,请重新登录', [], -1);
  49. }
  50. $controller = $request->controller();
  51. $is_kefu = 0;
  52. //token临近过期,自动续期
  53. if ($adminInfo) {
  54. //客服派单员
  55. if (isset($adminInfo['role_name']) && (strpos($adminInfo['role_name'], '派单') !== false || strpos($adminInfo['role_name'], '客服') !== false)) {
  56. //获取临近过期自动续期时长
  57. $beExpireDuration = Config::get('project.kefu_admin_token.be_expire_duration');
  58. $is_kefu = 1;
  59. } else {
  60. //获取临近过期自动续期时长
  61. $beExpireDuration = Config::get('project.admin_token.be_expire_duration');
  62. }
  63. //token续期
  64. if (time() > ($adminInfo['expire_time'] - $beExpireDuration)) {
  65. if ($is_kefu == 1 && $controller == 'notice.Notice') {
  66. } else {
  67. $result = AdminTokenService::overtimeToken($token);
  68. //续期失败(数据表被删除导致)
  69. if (empty($result)) {
  70. return JsonService::fail('登录过期', [], -1);
  71. }
  72. }
  73. }
  74. }
  75. //给request赋值,用于控制器
  76. $request->adminInfo = $adminInfo;
  77. $request->adminId = $adminInfo['admin_id'] ?? 0;
  78. return $next($request);
  79. }
  80. }