参照http://laravelacademy.org/post/3502.html这个教程做前后台用户认证的时候
遇到一个问题就是,未登录用户访问/admin的时候,本来应该跳转到/admin/login的,但是不知道为什么总是跳转到/login去
请教这是什么原因?
PHP中文网2017-05-16 16:55:08
AppHttpMiddleware下的Authenticate
return redirect()->guest('admin/login');
即可
天蓬老师2017-05-16 16:55:08
Authenticate 中间件
public function handle($request, Closure $next, $guard = null)
{
if (Auth::guard($guard)->guest()) {
if ($request->ajax()) {
return response('Unauthorized.', 401);
} else {
return redirect()->guest($guard.'/login'); //注意这里的$guard
}
}
return $next($request);
}
route.php
Route::group(['middleware' => ['auth:admin']], function () { // auth:admin 调用auth中间件的时候传递一个admin,这个admin正好是被中间件的$guard接收,于是访问后台的时候都会被跳转导admin/login,同理 前台用户登陆的中间件可以是 auth:user , 这样会跳转到user/login
Route::get('admin/index', 'AdminController@index');
});