我正在尝试为具有相同URI的授权用户(中间件身份验证)和访客(中间件访客)使用differt控制器,但我无法在laravel 5.3中使用它。
我尝试使用相同的URI和differt中间件制作2条路由,但是不可能创建具有相同URI的2条路由。
我尝试了很多东西但是在laravel 5.3中我不能在routes文件中使用Auth::check()
,它总是会返回false:
Route::get('/', [
'as' => 'home',
'uses' => (Auth::check() ? 'User\DashboardController' : 'Guest\HomeController'),
]);
我也尝试在路线中使用一个功能:
Route::get('/', [
'as' => 'home',
'uses' => function (){
$app = app();
if(Auth::check()){
$controller = $app->make('App\Http\Controllers\User\DashboardController');
return $controller->callAction('getIndex', $parameters = []);
}else{
$controller = $app->make('App\Http\Controllers\Guest\HomeController');
return $controller->callAction('getIndex', $parameters = []);
}
}
]);
现在Auth::check()
大部分都有效,但现在控制器__construct
函数中的中间件被忽略了。这看起来不太好。
当我从登录路由重定向到此路由时,我也遇到了问题Auth::check()
返回false。但是,如果我刷新页面,它将返回true。
我不想使用1个控制器并处理该控制器中的用户和来宾,这是因为我的用户控制器扩展了另一个类而不是我的访客控制器。
有人知道如何为客人提供1条带控制器的路由,为授权用户提供不同的控制器吗?
答案 0 :(得分:2)
您可以创建新的中间件:
<?php
namespace App\Http\Middleware;
use Closure;
class isGuest
{
public function handle($request, Closure $next)
{
if (! \Auth::check()) {
return redirect('/guest-page');
}
return $next($request);
}
}
然后你需要在app / Http / Kernel.php
中注册新的中间件protected $routeMiddleware = [
'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
'can' => \Illuminate\Auth\Middleware\Authorize::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
];
然后将其附加到所需的路线:
Route::get('user', [
'uses' => 'UsersController@index',
'as' => 'users.index'
])->middleware('isGuest');
您还可以为一条路线使用多个中间件:
Route::get('user', [
'uses' => 'UsersController@index',
'as' => 'users.index'
])->middleware('isGuest', 'secondMiddleware' ...);
此处提供更多信息:https://laravel.com/docs/5.3/middleware#global-middleware