使用中间件Laravel 7时无法登录

时间:2020-08-28 06:39:55

标签: php laravel laravel-7

我的Laravel身份验证出现问题。我无法重定向到登录时应该去的页面。因此,当我使用中间件时,它将再次重定向回我的登录页面。我正在使用中间件,因为它是多种身份验证类型。

Web.php路由

Auth::routes();

Route::group(['middleware' => 'auth'], function() {
    Route::get('/', 'HomeController@index')->name('home');
    Route::get('/inbox', 'HomeController@nonadmin')->middleware('admin')->name('inbox');

    //Route::get('/department', 'DepartmentController@index');
    Route::resource('department', 'DepartmentController');
    Route::resource('admin', 'AdminController');
    Route::resource('faculty', 'FacultyController');
    Route::resource('student', 'StudentController');
    //Route::get('logout', '\App\Http\Controllers\Auth\LoginController@logout');
    Auth::logout();
});

Admin.php中间件


namespace App\Http\Middleware;

use Closure;
use Auth; 

class Admin
{
   /**
       * Handle an incoming request.
       *
       * @param  \Illuminate\Http\Request  $request
       * @param  \Closure  $next
       * @return mixed
       */
   public function handle($request, Closure $next)
   {
       if (!Auth::check()) {
           return redirect()->route('login');
       }

       if(Auth::user()->user_type == 'Admin' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('dashboard');
       }
       
       if(Auth::user()->user_type == 'Staff' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('dashboard');
       }

       if(Auth::user()->user_type == 'Faculty' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('inbox');
       }
       
       if(Auth::user()->user_type == 'Student' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('inbox');
       }

       if(Auth::user()->user_type == 'Parent' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('inbox');
       }
   }
}

LoginController

use AuthenticatesUsers;

/**
    * Where to redirect users after login.
    *
    * @var string
    */
protected $redirectTo = '/';

/**
    * Create a new controller instance.
    *
    * @return void
    */
public function __construct()
{
    $this->middleware('guest')->except('logout');
}

public function logout(Request $request) {
    Auth::logout();
    return redirect('/');
}

public function username()
{
    return 'username';
}

我还在Kernel.php中声明了中间件,我在以前的项目中使用了该中间件。但是在当前使用Laravel 7当前版本的当前版本中,所有这些都在登录页面上重定向。

更新:

我根据Qirel的建议更新了路线。

Auth::routes();
Route::group(['middleware' => 'auth'], function() {
    Route::get('/', 'HomeController@index')->middleware('admin')->name('home');
    Route::get('/inbox', 'HomeController@nonadmin')->name('inbox');

    //Route::get('/department', 'DepartmentController@index');
    Route::resource('department', 'DepartmentController');
    Route::resource('admin', 'AdminController');
    Route::resource('faculty', 'FacultyController');
    Route::resource('student', 'StudentController');
});

我也将return $next($request);放在中间件上,最后一部分仍然无法使用。我想知道在我当前的项目中,它不起作用,但是在过去,它正在起作用。

2 个答案:

答案 0 :(得分:0)

在您的路线中,您已经

Auth::logout();

..它似乎是您添加的,因为您认为它为您添加了注销路径。该方法实际上将尝试注销用户!-它不会添加任何路由。当前发生的情况是,每当对任何用户进行身份验证时,它将呈现该组中的路由,然后将其注销,从而导致无法登录。

您的解决方案只是从路线中删除Auth::logout()

要显式添加注销路由,您需要添加

Auth::routes(['only' => 'logout']);

但是,您不需要这样做-因为您已经通过在顶部添加Auth::routes()来包含所有身份验证路由,从而为您处理了所有事务。

答案 1 :(得分:0)

第1步

您在admin.php中间件中编写以下功能

public function handle($request, Closure $next)
   {
       if (!Auth::check()) {
           return redirect()->route('login');
       }

       if(Auth::user()->user_type == 'Admin' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('dashboard');
       }
       
       if(Auth::user()->user_type == 'Staff' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('dashboard');
       }

       if(Auth::user()->user_type == 'Faculty' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('inbox');
       }
       
       if(Auth::user()->user_type == 'Student' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('inbox');
       }

       if(Auth::user()->user_type == 'Parent' &&  Auth::user()->status == 'Active')
       {
           return redirect()->route('inbox');
       }
   }

因此它不会因为检查登录+角色+状态而同时担心,因此当任何人需要登录时,它就不会处于活动状态。

请用以下代码替换该功能

public function handle($request, Closure $next)
   {
       if (!Auth::check()) {
           return redirect()->route('login');
       }

       if(Auth::user()->user_type == 'Admin')
       {
           return redirect()->route('dashboard');
       }
       
       if(Auth::user()->user_type == 'Staff' )
       {
           return redirect()->route('dashboard');
       }

       if(Auth::user()->user_type == 'Faculty')
       {
           return redirect()->route('inbox');
       }
       
       if(Auth::user()->user_type == 'Student')
       {
           return redirect()->route('inbox');
       }

       if(Auth::user()->user_type == 'Parent' )
       {
           return redirect()->route('inbox');
       }
   }

第2步

在您的logincontroller.php文件中编写

   public function logout(Request $request) {
    Auth::logout();
    return redirect('/');
}

public function __construct()
{
    $this->middleware('guest')->except('logout');
}

因此请删除该功能,然后将其粘贴到logincontroller.php中的行

public function __construct()
    {
        $this->middleware('auth');   
    }

现在,它将重定向到“ /”路由或您想要的路由。