作为一种开源的 PHP Web 框架,Laravel 一直以来都备受 Web 开发者的青睐。其强大的功能与易用性皆为其优势。对于一个 Web 应用来说,登录是非常基础的功能之一。在 Laravel 中,我们可以很快地实现用户登录,并且进行跳转。
下面,我们就来讲一下 Laravel 中用户登录和跳转的实现方法。
在开始编写代码之前,我们首先需要确保以下条件:
如果你还没有开启 Laravel 的身份认证功能,可以在终端里进入到项目根目录并输入以下命令:
php artisan make:auth
对于已经开启身份认证功能的 Laravel 项目,我们便可以按照以下步骤进行实现。
在 Laravel 中,我们可以通过表单来获取用户输入的用户名和密码。一般而言,我们会在表单中设置为 Post 方法,并且提交到一个叫做 LoginController 的控制器中,如下代码所示:
<form method="POST" action="{{ route('login') }}"> @csrf <div> <label for="email">邮箱</label> <div> <input id="email" type="email" name="email" value="{{ old('email') }}" required autocomplete="email" autofocus> </div> </div> <div> <label for="password">密码</label> <div> <input id="password" type="password" name="password" required autocomplete="current-password"> </div> </div> <div> <div> <div> <input type="checkbox" name="remember" id="remember" {{ old('remember') ? 'checked' : '' }}> <label for="remember"> 记住我 </label> </div> </div> </div> <div> <div> <button type="submit"> 登录 </button> @if (Route::has('password.request')) <a href="{{ route('password.request') }}"> 忘记密码了? </a> @endif </div> </div> </form>
当用户填写完表单信息后,点击“登录”按钮,便会提交数据到 LoginController 控制器中。
我们在 app/Http/Controllers/Auth/LoginController.php 文件中找到 login 方法,将该方法的内容修改如下:
use IlluminateHttpRequest; public function login(Request $request) { $credentials = $request->only('email', 'password'); if (Auth::attempt($credentials)) { // 认证成功后的操作 } return back()->withErrors( ['email' => '用户名或密码错误'] ); }
以上代码中,我们首先获取了用户表单所提交的数据,即邮箱和密码。紧接着,我们尝试使用 Auth::attempt() 方法对用户进行身份认证。如果用户认证成功,则在 if 语句中进行后续操作,否则返回错误信息,提示用户用户名或密码错误,并重新加载登录界面。
当用户成功登录之后,我们需要将用户跳转到指定的页面。在 Laravel 中,有两种实现方式,分别如下。
我们可以通过在 LoginController 控制器中增加 authenticated() 方法,来实现重定向到指定页面。该方法会在用户认证成功后自动调用。修改后的 LoginController 控制器代码如下:
use IlluminateHttpRequest; public function login(Request $request) { $credentials = $request->only('email', 'password'); if (Auth::attempt($credentials)) { return redirect()->intended('/home'); } return back()->withErrors( ['email' => '用户名或密码错误'] ); } protected function authenticated(Request $request, $user) { return redirect('/home'); }
以上代码中,我们可以看到 authenticated() 方法,该方法将用户重定向到 /home 页面。
我们也可以在登录成功后,通过注册路由的方式来实现重定向。在 web.php 文件中,我们注册以下路由:
Route::get('/home', function () { return view('home'); })->name('home'); Route::group(['middleware' => 'auth'], function () { Route::get('/', function () { return redirect()->route('home'); }); });
以上代码中,我们在 auth 中间件中注册了默认的根路由 /,当用户登录成功后,会自动重定向到 /home 页面中。
以上便是在 Laravel 中用户登录和跳转的方法。Laravel 提供的身份认证功能,为我们快速实现用户登录提供了极大的帮助。同时,通过控制器和路由两种方式,我们也可以对用户的跳转进行细致控制。
以上是laravel 登录 跳转的详细内容。更多信息请关注PHP中文网其他相关文章!