Laravel 驗(yàn)證碼認(rèn)證學(xué)習(xí)記錄小結(jié)
注:此處所用的注冊(cè)等系列功能,均作用于 laravel 自帶的用戶認(rèn)證機(jī)制
注冊(cè)驗(yàn)證碼
1. composer 安裝驗(yàn)證碼
composer require "mews/captcha:~3.0"
2. 運(yùn)行以下命令生成配置文件 config/captcha.php
php artisan vendor:publish --provider='Mews.aptcha.aptchaServiceProvider'
3. 前端展示驗(yàn)證碼
<img class="thumbnail captcha mt-3 mb-2" src="{{ captcha_src('flat') }}" onclick="this.src='/captcha/flat?'+Math.random()" title="點(diǎn)擊圖片重新獲取驗(yàn)證碼">
4. 后端驗(yàn)證(該擴(kuò)展包是為 Laravel 定制的擴(kuò)展包,完全兼容 laravel 注冊(cè)功能,驗(yàn)證非常方便)只需要在 app/Http/Controllers/Auth/RegisterController.php 中的驗(yàn)證規(guī)則中加入如下代碼:
'captcha' => ['required', 'captcha'],
郵箱認(rèn)證
laravel 自帶郵箱認(rèn)證
laravel 自帶的郵箱認(rèn)證文件位于 vendor/laravel/framework/src/Illuminate/Auth/MustVerifyEmail.php ,因?yàn)榇宋募捎?trait 聲明,因此我們快速的將內(nèi)容通過 use 集成到用戶的模型中,并進(jìn)行調(diào)用,如下:
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;
為了代碼的規(guī)范,我們可以接入 larave 自帶的郵箱驗(yàn)證接口 Illuminate\Contracts\Auth\MustVerifyEmail,規(guī)定模型必須擁有相關(guān)的方法,具體方法如下(方法在 MustVerifyEmailTrait 中已經(jīng)定義好,直接調(diào)用既可):
- hasVerifiedEmail() 檢測(cè)用戶 Email 是否已認(rèn)證;
- markEmailAsVerified() 將用戶標(biāo)示為已認(rèn)證;
- sendEmailVerificationNotification() 發(fā)送 Email 認(rèn)證的消息通知,觸發(fā)郵件的發(fā)送;
- getEmailForVerification() 獲取發(fā)送郵件地址,提供這個(gè)接口允許你自定義郵箱字段。
發(fā)送郵件
我們使用了 Laravel 自帶的 RegisterController ,控制器通過加載 Illuminate.oundation.uth.egistersUsers trait 來引入框架的注冊(cè)功能,此時(shí)我們打開此 trait 來翻閱源碼并定位到 register(Request $request) 方法:
public function register(Request $request) { // 檢驗(yàn)用戶提交的數(shù)據(jù)是否有誤 $this->validator($request->all())->validate(); // 創(chuàng)建用戶同時(shí)觸發(fā)用戶注冊(cè)成功的事件,并將用戶傳參 event(new Registered($user = $this->create($request->all()))); // 登錄用戶 $this->guard()->login($user); // 調(diào)用鉤子方法`registered()` return $this->registered($request, $user) ?: redirect($this->redirectPath()); }
此方法處理了用戶提交表單后的邏輯,我們把重點(diǎn)放在 event(new Registered($user = $this->create($request->all())));,這里使用了 Laravel 的事件系統(tǒng),觸發(fā)了 Registered 事件。
打開 app/Providers/EventServiceProvider.php 文件,此文件的 $listen 屬性里我們可以看到注冊(cè)了 Registered 事件的監(jiān)聽器:
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()) { // 發(fā)送郵件認(rèn)證消息通知(認(rèn)證郵件) $event->user->sendEmailVerificationNotification(); } } }
可以看出 Laravel 默認(rèn)已經(jīng)為我們?cè)O(shè)置了郵件發(fā)送的邏輯,接下來我們來測(cè)試一下。
測(cè)試郵件
測(cè)試之前,我們先設(shè)置下郵件發(fā)送到 log 中,以便后面的測(cè)試:
修改環(huán)境設(shè)置文件.env
MAIL_DRIVER=log
郵件一般發(fā)在 storage/logs 目錄下的日志文件中
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
PHP實(shí)現(xiàn)使用優(yōu)酷土豆視頻地址獲取swf播放器分享地址
這篇文章主要介紹了PHP實(shí)現(xiàn)使用優(yōu)酷土豆視頻地址獲取swf播放器分享地址,即分析優(yōu)酷土豆的視頻頁面地址,從而獲得對(duì)應(yīng)的swf播放器分享地址,需要的朋友可以參考下2014-06-06Ubuntu VPS中wordpress網(wǎng)站打開時(shí)提示”建立數(shù)據(jù)庫連接錯(cuò)誤”的解決辦法
這篇文章給大家介紹的是在Ubuntu VPS中wordpress網(wǎng)站打開時(shí)提示”建立數(shù)據(jù)庫連接錯(cuò)誤”的解決辦法,相信"建立數(shù)據(jù)庫連接錯(cuò)誤"大家并不陌生,最近我在做一個(gè)項(xiàng)目的時(shí)候就又遇到了這個(gè)問題,現(xiàn)在將我解決的步驟分享給大家,希望對(duì)同樣遇到這個(gè)問題的朋友們能有所幫助。2016-11-11