dongtuanzi1080 2018-11-29 09:10
浏览 49
已采纳

一旦用户登录,Laravel定制防护不起作用

I have a custom login controller that is meant to set a custom guard depending on a users access level, which will determine what they can access on the site.

the login works, however when i add middleware to protect the routes, it returns null and i'm not sure this is the correct way to set the guard based on the user login.

currently the code just loops back to the login page, and the custom guard returns null.

// loginController.php
    if (Auth::attempt($request->only('email', 'password'))) {
         Auth::login(Auth::user(), true);       
         $this->guard('custom_user');
         return redirect('/home');
    }

    protected function guard($custom_user){
        return Auth::guard($custom_user);
    }

// config/auth.php 
    'guards' => [
        'custom_user' => [
            'driver' => 'session',
            'provider' => 'users',
        ],
    ],
    'providers' => [
       'users' => [
            'driver' => 'eloquent',
            'model' => App\User::class,
       ],
    ],

// middleware/RedirectIfAuthenticaed.php
    public function handle($request, Closure $next)
    {
        if (Auth::guard('custom_user')->check()) {
            return $next($request);
        }
        return redirect('/login');
    }

* UPDATE *

I fixed the issue, was because i was setting secure cookies, but working on a local environment. Both solutions worked, just needed an SSL.

  • 写回答

2条回答 默认 最新

  • doumu8217 2018-11-29 09:37
    关注

    Auth::attempt and Auth::login in your LoginController will use the default guard defined in config/auth.php. You have to specify which guard they should use.

    And your $this->guard('custom_user') on its own will not do anything because it only returns a Auth instance.

    Change your default guard to custom_user or change this in your Controller:

    if ($this->guard('custom_user')->attempt($request->only('email', 'password'))) {
         $this->guard('custom_user')->login(Auth::user(), true);
         return redirect('/home');
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?