参照http://laravelacademy.org/post/3502.html这个教程做前后台用户认证的时候遇到一个问题就是,未登录用户访问/admin的时候,本来应该跳转到/admin/login的,但是不知道为什么总是跳转到/login去请教这是什么原因?
闭关修行中......
应该在中间件里修改跳转地址
AppHttpMiddleware下的Authenticatereturn redirect()->guest('admin/login');即可
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'); });
应该在中间件里修改跳转地址
AppHttpMiddleware下的Authenticate
return redirect()->guest('admin/login');
即可
Authenticate 中间件
route.php