Auth不适用于自定义中间件

时间:2017-08-08 17:50:41

标签: php laravel authentication laravel-5 laravel-5.3

我在LoginController中修改了Login函数,这就是我写的

public function login(Request $request)
{
    $data = $request->all();
    if($this->validateLogin((array)$data))
    {
        $cred = $request->email;
        $cred_p = $request->password;

        //if()
        $user = User::select('id', 'password')->where('email','=',$cred)->first();

        if(count($user) == 1)
        {
            if(Hash::check($cred_p, $user->password))
            {
                $user_id = $user->id;

                $status = User_status::select('is_active', 'is_completed')->where('user_id','=',$user_id)-> first();

                $active = $status->is_active;
                //dd($status->is_active);
                if($active == 0)
                {
                    return redirect()->to('/login')->withErrors(['status'=>"Your account is blocked. Please contact administrator or visit here <a href='/support/acount-blocked'>Support Center</a>"]);
                }
                else
                {
                        $this->attemptLogin($request);

                        $this->sendLoginResponse($request);                
                }
            }
            else
            {
                if ($this->hasTooManyLoginAttempts($request)) {
                    $this->fireLockoutEvent($request);

                    return $this->sendLockoutResponse($request);
                }
                $this->incrementLoginAttempts($request);
                return $this->sendFailedLoginResponse($request);
            }

        }
        else
        {
            return $this->sendFailedLoginResponse($request);
        }
    }
    else
    {
        return $this->sendFailedLoginResponse($request);
    }
}

这似乎工作正常,Auth::user()正在运行但是当我添加IsCompletedMiddleware的新中间件并且我检查dd(Auth::user());时,这将返回空值。

public function handle($request, Closure $next)
{

    /*if(Auth::user()->status->is_completed == 0)
    {
        return redirect()->to('/profile/management/complete');
    }*/
    return $next($request);
}

我还在中间件的标题中包含了use Auth;,但它总是返回null值。在其他控制器中Auth::user()返回适当的用户。为什么会这样?缺少什么。请帮忙谢谢。

1 个答案:

答案 0 :(得分:0)

在您的中间件中,您必须让用户正在执行请求,尝试执行此操作:

public function handle($request, Closure $next)
{
    $request = $next($request);
    if($request->user()->status->is_completed == 0){
        return redirect()->to('/profile/management/complete');
    }

    return $request;
}