laravel 登陆后跳转

在开发 web 应用程序时,用户登录认证是一个必不可少的功能。laravel 框架提供了多种方式实现用户认证,而且还提供了一套默认的身份认证系统(即 laravelilluminateauth),方便开发者在应用程序中实现用户注册、登录、退出等功能。

对于登录认证成功后,我们常常希望跳转到特定页面,比如用户的个人资料页,或者某个特定功能页。在 Laravel 框架中,实现登录后跳转非常简单。

本文将介绍 Laravel 框架中用户登录后跳转的几种方式。

Laravel 框架默认的登录跳转

LaravelIlluminateAuth 提供的身份认证系统默认配置了用户登录后的跳转。在 config/auth.php 配置文件中,有如下默认配置:

'redirect' => [     'login' => '/login',     'logout' => '/logout',     'home' => '/home',     'register' => '/register',     'verify' => '/email/verify',     'reset' => '/password/reset',     'confirm' => '/password/confirm',   ],

其中,’home’ 表示登录后的跳转页面,默认为 /home 路径。如果需要修改默认跳转页面,只需要将该路径修改为自己想要的页面即可。

手动指定跳转路径

如果需要在控制器中手动指定登录后的跳转页面,我们可以使用 Laravel 框架提供的 RedirectResponse 实例,通过 redirect() 方法实现。

例如,在用户控制器中,我们可以重写 IlluminateFoundationAuthAuthenticatesUsers trait 中的 authenticated() 方法:

use IlluminateSupportFacadesAuth;  class UserController extends Controller {     use AuthenticatesUsers;      protected function authenticated(Request $request, $user)     {         return redirect()->route('user.show', $user->id);     } }

上述代码可以在用户登录成功后,跳转到指定的用户个人资料页。

重定向到先前页面

有时候,我们需要将用户登录后的跳转路径设置为登录之前的页面,可以使用 Laravel 提供的 Session() 函数和 URL::previous() 方法。

例如,在登录控制器中,我们可以这样实现:

use IlluminateHttpRequest; use IlluminateSupportFacadesAuth; use IlluminateSupportFacadesURL;  class LoginController extends Controller {     public function login(Request $request)     {         $credentials = $request->only('email', 'password');         if (Auth::attempt($credentials)) {             return redirect()->intended(URL::previous());         }         return back()->withErrors(['email' => '登录失败']);     } }

在上述代码中,我们使用了 redirect()->intended() 方法,该方法会将用户重定向到登录之前访问的页面。如果用户之前没有访问过其他页面,则会重定向至默认的登录跳转路径。

使用中间件跳转到指定页面

Laravel 框架中间件提供了便捷的身份认证和授权功能。我们可以在某个中间件中指定登录后的跳转路径。

例如,我们可以在 auth 中间件中配置登录后的跳转路径:

namespace AppHttpMiddleware;  use IlluminateAuthMiddlewareAuthenticate as Middleware;  class Authenticate extends Middleware {     protected function redirectTo($request)     {         if (! $request->expectsjson()) {             return route('login'); // 设置默认的跳转路径         }     } }

在上述代码中,我们使用 redirectTo() 方法来处理登录失败的请求。如果请求时期望返回 json 格式数据,则直接返回 401 错误;否则,将用户重定向到登录页面。

如果需要指定其他的跳转路径,只需要修改 return 语句中的路由别名即可。

总结

© 版权声明
THE END
喜欢就支持一下吧
点赞5 分享