| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 | 
							- <?php
 
- namespace App\Http\Middleware;
 
- use App\Http\Controllers\Api\LoginController;
 
- use App\Service\EmployeeService;
 
- use Closure;
 
- use App\Service\TokenService;
 
- class CheckLogin
 
- {
 
-     /**
 
-      * Handle an incoming request.
 
-      *
 
-      * @param  \Illuminate\Http\Request  $request
 
-      * @param  \Closure  $next
 
-      * @return mixed
 
-      */
 
-     public function handle($request, Closure $next)
 
-     {
 
-         $token=$request->header('Authorization');
 
-         if(empty($token)) return response()->json(['code'=>1,'msg'=>'缺少登录凭证','data'=>null]);
 
-         //登录来源前缀清除
 
-         foreach (LoginController::$port as $key => $value){
 
-             if (strpos($token,$key) !== false) {
 
-                 $token = str_replace($key, $value, $token);
 
-                 break;
 
-             }
 
-         }
 
-         //校验token
 
-         $return = TokenService::verifyToken($token);
 
-         $user_id = $return['user_id'] ?? 0;
 
-         if ($user_id <= 0) return response()->json(['code'=>1,'msg'=>TokenService::error[$user_id],'data'=>null]);
 
-         //密码
 
-         $psd = $return['psd'] ?? "";
 
-         if(empty($psd)) return response()->json(['code'=>1,'msg'=>'账号密码失效,请重新登录','data'=>null]);
 
-         //校验用户
 
-         $checkResult = EmployeeService::checkUser($user_id, $psd);
 
-         list($state, $data) = $checkResult;
 
-         if(! $state) return response()->json(['code'=>1,'msg'=>$data,'data'=>null]);
 
-         //人员角色
 
-         $data['role'] = EmployeeService::getPersonRole($user_id);
 
-         //部门权限
 
-         $data['rule_depart'] = EmployeeService::getPersonDepart($user_id);
 
-         //写入user信息
 
-         $request->userData = $data;
 
-         return $next($request);
 
-     }
 
- }
 
 
  |