我使用的是Laravel Framework 5.4.10,我正在使用
的常规身份验证php artisan make:auth
提供。我想保护整个应用程序,并在登录后将用户重定向到/ themes。
我有4个控制器:ForgotPasswordController.php,LoginController.php,RegisterController.php和ResetPasswordController.php。我已将此行编辑为最后三行:
protected $redirectTo = '/themes';
这是我的routes / web.php中的第一行:
Auth::routes();
我在Controller.php中添加了这个功能:
public function __construct()
{
$this->middleware('auth');
}
我编辑了app / Http / Middleware / RedirectIfAuthenticated.php,因此handle函数如下所示:
public function handle($request, Closure $next, $guard = null)
{
if (Auth::guard($guard)->check()) {
return redirect('/themes');
}
return $next($request);
}
一切都很好,除非我点击“登录”按钮,我被重定向到“/”,而不是“/ themes”。如果我不需要在控制器中进行身份验证(Controller.php文件中没有__contruct函数),我会在登录时重定向。我究竟做错了什么?
答案 0 :(得分:52)
这就是我正在工作的东西,真是巧合。
您还需要在 LoginController
中添加以下行namespace App\Http\Controllers\Auth;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use Illuminate\Http\Request;
class LoginController extends Controller
{
/*
|--------------------------------------------------------------------------
| Login Controller
|--------------------------------------------------------------------------
|
| This controller handles authenticating users for the application and
| redirecting them to your home screen. The controller uses a trait
| to conveniently provide its functionality to your applications.
|
*/
use AuthenticatesUsers;
protected function authenticated(Request $request, $user)
{
if ( $user->isAdmin() ) {// do your margic here
return redirect()->route('dashboard');
}
return redirect('/home');
}
/**
* Where to redirect users after login.
*
* @var string
*/
//protected $redirectTo = '/admin';
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware('guest', ['except' => 'logout']);
}
}
答案 1 :(得分:9)
如果您查看AuthenticatesUsers特征,您会在sendLoginResponse方法中看到对$this->redirectPath()
的调用。如果你看一下这个方法,你就会发现redirectTo可以是方法,也可以是变量。
这就是我现在在我的auth控制器中所拥有的。
public function redirectTo() {
$user = Auth::user();
switch(true) {
case $user->isInstructor():
return '/instructor';
case $user->isAdmin():
case $user->isSuperAdmin():
return '/admin';
default:
return '/account';
}
}
答案 2 :(得分:7)
我通过使用AuthenticatesUsers特性来完成它。
\App\Http\Controllers\Auth\LoginController.php
将此方法添加到该控制器:
/**
* Check user's role and redirect user based on their role
* @return
*/
public function authenticated()
{
if(auth()->user()->hasRole('admin'))
{
return redirect('/admin/dashboard');
}
return redirect('/user/dashboard');
}
答案 3 :(得分:1)
您应该将$ redirectTo值设置为您想要重定向的路由
$this->redirectTo = route('dashboard');
在AuthController构造函数中。
/**
* Where to redirect users after login / registration.
*
* @var string
*/
protected $redirectTo = '/';
/**
* Create a new authentication controller instance.
*
* @return void
*/
public function __construct()
{
$this->middleware($this->guestMiddleware(), ['except' => 'logout']);
$this->redirectTo = route('dashboard');
}
答案 4 :(得分:1)
你可以在LoginController中添加方法在顶部添加行$util.toJson($context.result)
,在这个添加方法之后,它对我来说是wkwkwkwkw,但你必须在视图管理员和用户
use App\User;
{{ csrf_field() }}
答案 5 :(得分:1)
Path Customization(在laravel 7中测试)
成功验证用户身份后,他们将被重定向到/home
URI。您可以使用RouteServiceProvider
中定义的HOME常量来自定义验证后重定向路径:
public const HOME = '/home';
答案 6 :(得分:0)
根据Laravel documentation,我在app / Http / Controllers / Auth / LoginController.php中创建以下方法:
InputType.TYPE_CLASS_NUMBER | InputType.TYPE_NUMBER_FLAG_DECIMAL | InputType.TYPE_NUMBER_FLAG_SIGNED
要从数据库中获取用户信息,我使用了“ Illuminate \ Support \ Facades \ Auth;”。
答案 7 :(得分:0)
对于较新的Laravel版本,请将protected $redirectTo = RouteServiceProvider::HOME;
替换为protected $redirectTo = '/newurl';
,并相应地替换newurl
。
使用Laravel 6版进行测试
答案 8 :(得分:0)
转到提供程序-> RouteServiceProvider.php
更改路线,如下所示:
class RouteServiceProvider extends ServiceProvider
{
protected $namespace = 'App\Http\Controllers';
/**
* The path to the "home" route for your application.
*
* @var string
*/
public const HOME = '/dashboard';