在不生成Laravel默认身份验证控制器的情况下,我创建了自己的登录和注册控制器。
我的路线看起来像这些
登录
GET /login ->> SessionController@create -->name = login.create
POST /login ->> SessionController@store -->name = login.store
注册
GET /registration ->> RegistrationController@create -->name = register.create
POST /registration ->> RegistrationController@store -->name = register.store
一切都很好。现在我需要一件事。每当我放置auth
中间件时,未经过身份验证的用户都将被重定向到我的自定义登录页面路由login.create
。
怎么做?
答案 0 :(得分:3)
您可以扩展Illuminate\Auth\Middleware\Authenticate
中间件或只添加新的中间件:
class AuthMiddleware
{
public function handle($request, Closure $next)
{
if (auth()->guest()) {
return redirect()->route('login.create');
}
return $next($request);
}
}
在App\Http\Kernel.php
注册:
protected $routeMiddleware = [
'auth.custom' => \App\Http\Middleware\AuthMiddleware::class,
....
并使用:
Route::group(['middleware' => 'auth.custom'], function () {
// Protected routes.
});