作为一种开源的 php web 框架,laravel 一直以来都备受 web 开发者的青睐。其强大的功能与易用性皆为其优势。对于一个 web 应用来说,登录是非常基础的功能之一。在 laravel 中,我们可以很快地实现用户登录,并且进行跳转。

下面,我们就来讲一下 Laravel 中用户登录和跳转的实现方法。
前置条件
在开始编写代码之前,我们首先需要确保以下条件:

拥有 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>

登录后复制当用户填写完表单信息后,点击“登录”按钮,便会提交数据到 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中文网其它相关文章!