Laravel 验证码认证学习记录小结
注:此处所用的注册等系列功能,均作用于 laravel 自带的用户认证机制
注册验证码
1. composer 安装验证码
composer require "mews/captcha:~3.0"
2. 运行以下命令生成配置文件 config/captcha.php
php artisan vendor:publish --provider='mews.aptcha.aptchaserviceprovider'
3. 前端展示验证码
<img class="thumbnail captcha mt-3 mb-2" src="{{ captcha_src('flat') }}" onclick="this.src='/captcha/flat?'+math.random()" title="点击图片重新获取验证码">
4. 后端验证(该扩展包是为 laravel 定制的扩展包,完全兼容 laravel 注册功能,验证非常方便)只需要在 app/http/controllers/auth/registercontroller.php 中的验证规则中加入如下代码:
'captcha' => ['required', 'captcha'],
邮箱认证
laravel 自带邮箱认证
laravel 自带的邮箱认证文件位于 vendor/laravel/framework/src/illuminate/auth/mustverifyemail.php ,因为此文件采用 trait 声明,因此我们快速的将内容通过 use 集成到用户的模型中,并进行调用,如下:
namespace app\models; use illuminate\foundation\auth\user as authenticatable; use illuminate\notifications\notifiable; use illuminate\auth\mustverifyemail as mustverifyemailtrait; class user extends authenticatable { use notifiable, mustverifyemailtrait;
为了代码的规范,我们可以接入 larave 自带的邮箱验证接口 illuminate\contracts\auth\mustverifyemail,规定模型必须拥有相关的方法,具体方法如下(方法在 mustverifyemailtrait 中已经定义好,直接调用既可):
- hasverifiedemail() 检测用户 email 是否已认证;
- markemailasverified() 将用户标示为已认证;
- sendemailverificationnotification() 发送 email 认证的消息通知,触发邮件的发送;
- getemailforverification() 获取发送邮件地址,提供这个接口允许你自定义邮箱字段。
发送邮件
我们使用了 laravel 自带的 registercontroller ,控制器通过加载 illuminate.oundation.uth.egistersusers trait 来引入框架的注册功能,此时我们打开此 trait 来翻阅源码并定位到 register(request $request) 方法:
public function register(request $request) { // 检验用户提交的数据是否有误 $this->validator($request->all())->validate(); // 创建用户同时触发用户注册成功的事件,并将用户传参 event(new registered($user = $this->create($request->all()))); // 登录用户 $this->guard()->login($user); // 调用钩子方法`registered()` return $this->registered($request, $user) ?: redirect($this->redirectpath()); }
此方法处理了用户提交表单后的逻辑,我们把重点放在 event(new registered($user = $this->create($request->all())));,这里使用了 laravel 的事件系统,触发了 registered 事件。
打开 app/providers/eventserviceprovider.php 文件,此文件的 $listen 属性里我们可以看到注册了 registered 事件的监听器:
protected $listen = [ registered::class => [ sendemailverificationnotification::class, ], ];
打开 sendemailverificationnotification 类,阅读其源码:vendor/laravel/framework/src/illuminate/auth/listeners/sendemailverificationnotification.php
<?php namespace illuminate\auth\listeners; use illuminate\auth\events\registered; use illuminate\contracts\auth\mustverifyemail; class sendemailverificationnotification { /** * 处理事件 * * @param \illuminate\auth\events\registered $event * @return void */ public function handle(registered $event) { // 如果 user 是继承于 mustverifyemail 并且还未激活的话 if ($event->user instanceof mustverifyemail && ! $event->user->hasverifiedemail()) { // 发送邮件认证消息通知(认证邮件) $event->user->sendemailverificationnotification(); } } }
可以看出 laravel 默认已经为我们设置了邮件发送的逻辑,接下来我们来测试一下。
测试邮件
测试之前,我们先设置下邮件发送到 log 中,以便后面的测试:
修改环境设置文件.env
mail_driver=log
邮件一般发在 storage/logs 目录下的日志文件中
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 白血病的五大护理方法 白血病的护理原则
下一篇: Pandas标记删除重复记录的方法