首页 > php框架 > Laravel > 正文

laravel 登录 跳转

WBOY
发布: 2023-05-29 10:41:37
原创
364 人浏览过

作为一种开源的 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>
</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中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!