Email 认证

未匹配的标注
本文档最新版为 10.x,旧版本可能放弃维护,推荐阅读最新版!

Email 认证

简介

很多 Web 应用会要求用户在使用之前进行 Email 地址验证。Laravel 不会强迫你在每个应用中重复实现它,而是提供了便捷的方法来发送和校验电子邮件的验证请求。

Model 准备

在开始之前,需要验证你的 App\User 模型是否实现了 Illuminate\Contracts\Auth\MustVerifyEmail契约:

<?php

namespace App;

use Illuminate\Contracts\Auth\MustVerifyEmail;
use Illuminate\Foundation\Auth\User as Authenticatable;
use Illuminate\Notifications\Notifiable;

class User extends Authenticatable implements MustVerifyEmail
{
    use Notifiable;

    // ...
}

数据库注意事项

Email 验证字段

接下来,你的 user 表必须包含一个 email_verified_at 字段用来存储 Email 地址通过验证的时间。默认情况下,Laravel 框架中 users 表的数据迁移已经包含了这个字段。所以,您需要做的就只是执行数据库迁移:

php artisan migrate

路由

Laravel 的 Auth\VerificationController 类包含了发送验证链接和验证 Email 的必要逻辑。通过将 verify 选项传给 Auth::routes 方法,就能为这个控制器注册所需要的路由:

Auth::routes(['verify' => true]);

保护路由

路由中间件 可用于仅允许经过验证的用户访问指定路由。Laravel 附带了 verified 中间件,它定义在 Illuminate\Auth\Middleware\EnsureEmailIsVerified。由于此中间件已在应用程序的 HTTP 内核中注册,因此您需要做的就是将中间件附加到路由定义:

Route::get('profile', function () {
    // 只有经过验证的用户才能进..
})->middleware('verified');

视图

如果要生成Email验证的所有必要视图,您可以使用laravel / ui Composer包:

composer require laravel/ui --dev

php artisan ui vue --auth

Email验证视图文件位于resources / views / auth / verify.blade.php中。 你可以根据自己的应用自由地调整这些视图的样式。

邮箱认证之后

在邮箱认证之后,用户会自动被重定向至 /home。你可通过在 VerificationController 中定义一个 redirectTo 方法或者属性来调整认证之后的跳转位置。

protected $redirectTo = '/dashboard';

事件

Laravel在Email验证过程中发送事件。 你应该在 EventServiceProvider 中注册监听者:

/**
 * 应用程序的事件监听器
 *
 * @var array
 */
protected $listen = [
    'Illuminate\Auth\Events\Verified' => [
        'App\Listeners\LogVerifiedUser',
    ],
];

本文章首发在 LearnKu.com 网站上。

本译文仅用于学习和交流目的,转载请务必注明文章译者、出处、和本文链接
我们的翻译工作遵照 CC 协议,如果我们的工作有侵犯到您的权益,请及时联系我们。

原文地址:https://learnku.com/docs/laravel/7.x/ver...

译文地址:https://learnku.com/docs/laravel/7.x/ver...

上一篇 下一篇
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
贡献者:1
讨论数量: 1
发起讨论 只看当前版本


sunxyw
汉化 Email 认证邮件
5 个点赞 | 1 个回复 | 博客 | 课程版本 5.7