CheckLogin.php 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. <?php
  2. namespace App\Http\Middleware;
  3. use App\Http\Controllers\Api\LoginController;
  4. use App\Service\EmployeeService;
  5. use Closure;
  6. use App\Service\TokenService;
  7. class CheckLogin
  8. {
  9. const CODES = 401;//未经授权
  10. /**
  11. * Handle an incoming request.
  12. *
  13. * @param \Illuminate\Http\Request $request
  14. * @param \Closure $next
  15. * @return mixed
  16. */
  17. public function handle($request, Closure $next)
  18. {
  19. $token=$request->header('Authorization');
  20. if (!isset($token)){
  21. return response()->json(['code'=>self::CODES,'msg'=>'缺少token','data'=>null]);
  22. }
  23. //登录来源前缀清除
  24. foreach (LoginController::$port as $key => $value){
  25. if (strpos($token,$key) !== false) {
  26. $token = str_replace($key, $value, $token);
  27. break;
  28. }
  29. }
  30. //校验token
  31. $result = TokenService::verifyToken($token);
  32. if ($result < 0){
  33. return response()->json(['code'=>self::CODES,'msg'=>TokenService::error[$result],'data'=>null]);
  34. }
  35. //校验用户
  36. $checkResult = EmployeeService::checkUser($result);
  37. list($state, $data) = $checkResult;
  38. if(! $state) return response()->json(['code'=>self::CODES,'msg'=>$data,'data'=>null]);
  39. //人员角色
  40. // $data['role'] = EmployeeService::getPersonRole($result);
  41. //部门权限
  42. // $data['rule_depart'] = EmployeeService::getPersonDepart($result);
  43. //写入user信息
  44. $request->userData = $data;
  45. return $next($request);
  46. }
  47. }