LoginMiddleware.php 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. <?php
  2. // +----------------------------------------------------------------------
  3. // | whitef快速开发前后端分离管理后台(PHP版)
  4. // +----------------------------------------------------------------------
  5. // | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
  6. // | 开源版本可自由商用,可去除界面版权logo
  7. // | gitee下载:https://gitee.com/likeshop_gitee/whitef
  8. // | github下载:https://github.com/likeshop-github/whitef
  9. // | 访问官网:https://www.whitef.cn
  10. // | whitef团队 版权所有 拥有最终解释权
  11. // +----------------------------------------------------------------------
  12. // | author: whitefTeam
  13. // +----------------------------------------------------------------------
  14. declare (strict_types=1);
  15. namespace app\workerapi\http\middleware;
  16. use app\common\cache\MasterWokerTokenCache;
  17. use app\common\model\master_worker\MappingMworkerSession;
  18. use app\common\service\JsonService;
  19. use app\workerapi\service\MasterWokerTokenService;
  20. use think\facade\Config;
  21. class LoginMiddleware
  22. {
  23. /**
  24. * @notes 登录验证
  25. * @param $request
  26. * @param \Closure $next
  27. * @return mixed|\think\response\Json
  28. * @author 令狐冲
  29. * @date 2021/7/1 17:33
  30. */
  31. public function handle($request, \Closure $next)
  32. {
  33. $token = $request->header('token');
  34. $mapSession = MappingMworkerSession::where([['type', '=', 1],['token', '=', $token], ['expire_time', '>', time()]])->findOrEmpty();
  35. if(!$mapSession->isEmpty()) {
  36. $mapSession->map_token && $token = $mapSession->map_token;
  37. }
  38. //判断接口是否免登录
  39. $isNotNeedLogin = $request->controllerObject->isNotNeedLogin();
  40. //不直接判断$isNotNeedLogin结果,使不需要登录的接口通过,为了兼容某些接口可以登录或不登录访问
  41. if (empty($token) && !$isNotNeedLogin) {
  42. //没有token并且该地址需要登录才能访问, 指定show为0,前端不弹出此报错
  43. return JsonService::fail('请先进行登录', [], 401, 0);
  44. }
  45. $userInfo = (new MasterWokerTokenCache())->getUserInfo($token);
  46. if (empty($userInfo) && !$isNotNeedLogin) {
  47. //token过期无效并且该地址需要登录才能访问
  48. return JsonService::fail('登录超时,请重新登录', [], 401, 0);
  49. }
  50. //token临近过期,自动续期
  51. if ($userInfo) {
  52. if (!isset($userInfo['is_temporary']) ) {
  53. $userInfo = (new MasterWokerTokenCache())->setUserInfo($token);
  54. }
  55. //获取临近过期自动续期时长
  56. $beExpireDuration = Config::get('project.user_token.be_expire_duration');
  57. //token续期
  58. if (time() > ($userInfo['expire_time'] - $beExpireDuration)) {
  59. $result = MasterWokerTokenService::overtimeToken($token);
  60. //续期失败(数据表被删除导致)
  61. if (empty($result)) {
  62. return JsonService::fail('登录过期', [], 401);
  63. }
  64. }
  65. //临时工程师校验一下权限
  66. $controller = $request->controller();
  67. if (isset($userInfo['is_temporary']) && $userInfo['is_temporary'] == 1 && !in_array(strtolower($controller), ['groupworks','sms','login','upload','masterworkeragree'])) {
  68. return JsonService::fail('暂无权限', [], 401);
  69. }
  70. }
  71. //给request赋值,用于控制器
  72. $request->userInfo = $userInfo;
  73. $request->userId = $userInfo['user_id'] ?? 0;
  74. return $next($request);
  75. }
  76. }