laravel6开发论坛-邮箱验证

我们将只允许邮箱认证通过的用户使用网站,未认证用户会被引导进入验证邮箱页面。

『邮箱认证』工作机制一般分两步:

  1. 发送认证邮件 ------ 将附带认证信息的『认证链接』发送到用户邮箱里;

  2. 检测认证链接 ------ 用户打开邮件,点击认证链接进入网站,程序检测 URL 中认证参数的合法性,并渲染对应的页面。

以上流程非常通用,Laravel 默认自带了这个功能,我们可以很方便地进行集成。

屡一下产品思路:

  1. 用户注册成功后,给用户发送一个认证邮件;

  2. 用户登录状态下,如邮箱未认证,重定向到提醒验证邮箱的页面中。

修改模型存放位置

现在让我们先来创建一个 app/Models 文件夹,并将 User.php 文件放置到其中。

bash 复制代码
mv app/User.php app/Models/User.php

1、修改 User.php 文件,更改 namespace 为我们新创建的文件夹路径:

app/Models/User.php

php 复制代码
<?php

namespace App\Models;
.
.
.

编辑器全局搜索 App\User 替换为 App\Models\User ,按钮替换全部:

修改 User 模型

接下来我们将修改 User 模型,将 Laravel 自带的邮箱认证功能集成到我们的程序中。

php 复制代码
<?php

namespace App;

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

class User extends Authenticatable implements MustVerifyEmail
{
    use Notifiable;

    // ...
}

添加路由中间

路由中间件 可用于仅允许经过验证的用户访问指定路由。

rust 复制代码
Route::get('/', [\App\Http\Controllers\PagesController::class,'root'])->name('root')->middleware('verified'); // <-邮箱验证规则

->middleware('verified');// 只有经过验证的用户才能进..

开始测试

测试之前,我们先设置下邮件发送到 log 中,以便后面的测试:

.env

ini 复制代码
MAIL_DRIVER=smtp

修改成

MAIL_DRIVER=log

修改成功后浏览器访问larabbs.test:8080/register ,填写表单并注册一个测试用户:

注册成功后,打开日志存放目录 storage/logs ,打开最近一天的 .log 文件,在文件最尾部应可见类似以下:

邮件成功发送,复制以上的激活链接,找个地方记录起来,先不要浏览器访问,后续会用到。

接下来我们将使用 来过滤用户的所有请求,如果用户未认证的话,就跳转到邮件认证提醒的页面中。

go 复制代码
php artisan make:middleware EnsureEmailIsVerified

打开生成的文件并代入以下内容:

app/Http/Middleware/EnsureEmailIsVerified.php

php 复制代码
<?php

namespace App\Http\Middleware;

use Closure;

class EnsureEmailIsVerified
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        // 三个判断:
        // 1. 如果用户已经登录
        // 2. 并且还未认证 Email
        // 3. 并且访问的不是 email 验证相关 URL 或者退出的 URL。
        if ($request->user() &&
            ! $request->user()->hasVerifiedEmail() &&
            ! $request->is('email/*', 'logout')) {
            // 根据客户端返回对应的内容
            return $request->expectsJson()
                ? abort(403, '您的电子邮件地址未经验证.')
                : redirect()->route('verification.notice');
        }

        return $next($request);
    }
}

接下来注册中间件,注册的时机确保在 StartSession 后面即可:

app/Http/Kernel.php

ruby 复制代码
protected $middlewareGroups = [
    'web' => [
        \App\Http\Middleware\EncryptCookies::class,
        \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
        \Illuminate\Session\Middleware\StartSession::class,
        // \Illuminate\Session\Middleware\AuthenticateSession::class,
        \Illuminate\View\Middleware\ShareErrorsFromSession::class,
        \App\Http\Middleware\VerifyCsrfToken::class,
        \Illuminate\Routing\Middleware\SubstituteBindings::class,
        \App\Http\Middleware\EnsureEmailIsVerified::class, // <<--- 只需添加这一行,过滤用户的所有请求,如果用户未认证的话,就跳转到邮件认证提醒的页面中
    ],

刷新页面,即可看到认证提醒,并且除了我们上面代码中设置的 URL 外都会进入此页面:

内置邮箱认证还有个小功能,当你点击点击多次『重新发送 Email』后,系统会自动做限额处理,你可以在VerificationController 中配置相应的信息:

最后测试

相关推荐
程序猿麦小七10 分钟前
基于springboot的景区网页设计与实现
java·spring boot·后端·旅游·景区
蓝田~19 分钟前
SpringBoot-自定义注解,拦截器
java·spring boot·后端
theLuckyLong20 分钟前
SpringBoot后端解决跨域问题
spring boot·后端·python
.生产的驴21 分钟前
SpringCloud Gateway网关路由配置 接口统一 登录验证 权限校验 路由属性
java·spring boot·后端·spring·spring cloud·gateway·rabbitmq
小扳25 分钟前
Docker 篇-Docker 详细安装、了解和使用 Docker 核心功能(数据卷、自定义镜像 Dockerfile、网络)
运维·spring boot·后端·mysql·spring cloud·docker·容器
v'sir35 分钟前
POI word转pdf乱码问题处理
java·spring boot·后端·pdf·word
李少兄39 分钟前
解决Spring Boot整合Redis时的连接问题
spring boot·redis·后端
码上一元5 小时前
SpringBoot自动装配原理解析
java·spring boot·后端
枫叶_v7 小时前
【SpringBoot】22 Txt、Csv文件的读取和写入
java·spring boot·后端
杜杜的man8 小时前
【go从零单排】Closing Channels通道关闭、Range over Channels
开发语言·后端·golang