我的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);
放在中间件上,最后一部分仍然无法使用。我想知道在我当前的项目中,它不起作用,但是在过去,它正在起作用。
答案 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');
}
现在,它将重定向到“ /”路由或您想要的路由。