laravel框架郵箱認(rèn)證實現(xiàn)方法詳解
本文實例講述了laravel框架郵箱認(rèn)證實現(xiàn)方法。分享給大家供大家參考,具體如下:
修改 User 模型,將 Laravel 自帶的郵箱認(rèn)證功能集成到我們的程序中
<?php namespace App\Models; use Illuminate\Notifications\Notifiable; use Illuminate\Auth\MustVerifyEmail as MustVerifyEmailTrait; use Illuminate\Foundation\Auth\User as Authenticatable; use Illuminate\Contracts\Auth\MustVerifyEmail as MustVerifyEmailContract; class User extends Authenticatable implements MustVerifyEmailContract { use Notifiable, MustVerifyEmailTrait; /** * The attributes that are mass assignable. * * @var array */ protected $fillable = [ 'name', 'email', 'password', ]; /** * The attributes that should be hidden for arrays. * * @var array */ protected $hidden = [ 'password', 'remember_token', ]; /** * The attributes that should be cast to native types. * * @var array */ protected $casts = [ 'email_verified_at' => 'datetime', ]; }
代碼詳解:
加載使用 MustVerifyEmail
trait,打開 vendor/laravel/framework/src/Illuminate/Auth/MustVerifyEmail.php
文件,可以看到以下三個方法:
hasVerifiedEmail()
檢測用戶 Email 是否已認(rèn)證;markEmailAsVerified()
將用戶標(biāo)示為已認(rèn)證;sendEmailVerificationNotification()
發(fā)送 Email 認(rèn)證的消息通知,觸發(fā)郵件的發(fā)送。
得益于 PHP 的 trait 功能,User 模型在 use
以后,即可使用以上三個方法。
可以打開 vendor/laravel/framework/src/Illuminate/Contracts/Auth/MustVerifyEmail.php
,可以看到此文件為 PHP 的接口類,繼承此類將確保 User 遵守契約,擁有上面提到的三個方法。
如果我們使用了 Laravel 自帶的 RegisterController
,控制器通過加載 Illuminate\Foundation\Auth\RegistersUsers
trait 來引入框架的注冊功能,此時我們打開此 trait 來翻閱源碼并定位到 register(Request $request)
方法:
此方法處理了用戶提交表單后的邏輯,我們把重點放在 event(new Registered($user = $this->create($request->all())));
,這里使用了 Laravel 的事件系統(tǒng),觸發(fā)了 Registered
事件。
打開 app/Providers/EventServiceProvider.php
文件,此文件的 $listen
屬性里我們可以看到注冊了Registered
事件的監(jiān)聽器:
打開 SendEmailVerificationNotification
類,閱讀其源碼:
vendor/laravel/framework/src/Illuminate/Auth/Listeners/SendEmailVerificationNotification.php
可以看出 Laravel 默認(rèn)已經(jīng)為我們設(shè)置了郵件發(fā)送的邏輯
強(qiáng)制用戶認(rèn)證
我們希望用戶認(rèn)證郵箱后,才能使用網(wǎng)站。
我們將使用 Laravel 中間件 來過濾用戶的所有請求,如果用戶未認(rèn)證的話,就跳轉(zhuǎn)到郵件認(rèn)證提醒的頁面中
可以使用以下命令來新建一個中間件:
php artisan make:middleware EnsureEmailIsVerified
打開生成的文件并代入以下內(nèi)容:
app/Http/Middleware/EnsureEmailIsVerified.php
<?php namespace App\Http\Middleware; use Closure; class EnsureEmailIsVerified { public function handle($request, Closure $next) { // 三個判斷: // 1. 如果用戶已經(jīng)登錄 // 2. 并且還未認(rèn)證 Email // 3. 并且訪問的不是 email 驗證相關(guān) URL 或者退出的 URL。 if ($request->user() && ! $request->user()->hasVerifiedEmail() && ! $request->is('email/*', 'logout')) { // 根據(jù)客戶端返回對應(yīng)的內(nèi)容 return $request->expectsJson() ? abort(403, 'Your email address is not verified.') : redirect()->route('verification.notice'); } return $next($request); } }
接下來注冊中間件,注冊的時機(jī)確保在 StartSession
后面即可:
app/Http/Kernel.php
此時如果我們沒有認(rèn)證郵箱就會看到認(rèn)證提醒,并且除了我們上面代碼中設(shè)置的 URL 外都會進(jìn)入此頁面:
內(nèi)置郵箱認(rèn)證還有個小功能,當(dāng)你點擊點擊多次『重新發(fā)送 Email』后,系統(tǒng)會自動做限額處理,可以有效防止用戶消耗太多資源。你可以在 VerificationController
中配置相應(yīng)的信息:
更多關(guān)于Laravel相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Laravel框架入門與進(jìn)階教程》、《php優(yōu)秀開發(fā)框架總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計入門教程》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家基于Laravel框架的PHP程序設(shè)計有所幫助。
- Laravel 默認(rèn)郵箱登錄改成用戶名登錄的實現(xiàn)方法
- laravel5.4利用163郵箱發(fā)送郵件的步驟詳解
- 在Laravel框架里實現(xiàn)發(fā)送郵件實例(郵箱驗證)
- Laravel 5框架學(xué)習(xí)之用戶認(rèn)證
- 詳解Laravel5.6 Passport實現(xiàn)Api接口認(rèn)證
- Laravel5.5中利用Passport實現(xiàn)Auth認(rèn)證的方法
- Laravel實現(xiàn)用戶多字段認(rèn)證的解決方法
- Laravel認(rèn)證原理以及完全自定義認(rèn)證詳解
- Laravel多用戶認(rèn)證系統(tǒng)示例詳解
- 解決Laravel5.2 Auth認(rèn)證退出失效的問題
- laravel實現(xiàn)Auth認(rèn)證,登錄、注冊后的頁面回跳方法
相關(guān)文章
PHP 字符串編碼截取函數(shù)(兼容utf-8和gb2312)
昨天晚上和今天上午看了字符編碼的問題,還有一些別人截取字符串的函數(shù),自己也寫了一個,兼容utf-8和gb2312的2009-05-05PHP中使用strpos函數(shù)實現(xiàn)屏蔽敏感關(guān)鍵字功能
這篇文章主要介紹了PHP中使用strpos函數(shù)實現(xiàn)屏蔽敏感關(guān)鍵字功能,本文用在發(fā)布文章保存到數(shù)據(jù)庫時前攔截敏感關(guān)鍵,需要的朋友可以參考下2014-08-08Laravel5中實現(xiàn)模糊匹配加多條件查詢功能的方法
這篇文章主要介紹了Laravel5中實現(xiàn)模糊匹配加多條件查詢功能的方法,結(jié)合實例形式分析了Laravel5多條件模糊查詢及相關(guān)封裝操作技巧,需要的朋友可以參考下2018-03-03